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ABSTRACT 


This  report  presents  results  of  a  three  phase  effort  to  demonstrate  the  use  of 
convex  control  design  techniques  in  aeronautical  applications.  The  first  phase  was  the 
demonstration  of  a  methodology  by  which  classical  aircraft  controller  design  require¬ 
ments  could  be  translated  into  the  weighting  matrices  for  Woo  controller  synthesis. 
The  second  phase  extended  that  methodology  to  the  design  of  mixed  W2  /  Hoo  con¬ 
trollers.  The  third  phase  considered  the  problem  of  minimizing  the  size  of  aircraft 
control  surfaces  while  meeting  closed-loop  dynamic  performance  requirements. 

Control  sizing  is  a  critical  element  in  the  design  of  Reduced  Static  Stability 
(RSS)  aircraft.  Inadequate  control  power  places  the  vehicle  in  peril,  while  too  much 
control  power  forfeits  the  benefits  of  RSS,  resulting  in  poorer  performance,  increased 
weight,  increased  cost,  increased  drag,  and  increased  observability.  Non-heuristic 
methods  have  been  required  by  which  the  physical  configuration  and  the  accompa¬ 
nying  controller  can  be  designed  directly  from  the  flying  qualities  specifications.  The 
optimization  of  the  surfaces  should  be  done  while  searching  over  the  set  of  all  con¬ 
trollers  which,  together  in  closed-loop,  satisfy  the  flying  qualities  requirements.  This 
report  presents  a  methodology  which  simultaneously  optimizes  both  the  physical  con¬ 
figuration  and  the  control  system  of  a  rigid  body,  using  performance  requirements 
which  can  be  posed  as  Linear  Matrix  Inequalities. 
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I.  INTRODUCTION 


Aeronautical  applications  have  provided  much  of  both  the  rnotivation  and  re¬ 
sources  for  recent  advances  in  the  field  of  controls  engineering.  In  the  quest  for 
ever  improving  performance,  the  field  of  aerodynamics  matured  to  the  point  that 
only  incremental  gains  were  possible.  Consequently,  the  thrust  for  improved  perfor¬ 
mance  turned  instead  to  more  innovative  ways  of  controlling  air  vehicles —  allowing 
for  unstable  open-loop  dynamics,  shrinking  control  surfaces,  and  eliminating  mechan¬ 
ical  command  systems  in  favor  of  “fly-by-wire”  systems.  These  innovations  in  con¬ 
trols  permitted  the  industry  to  exploit  innovation  in  aerodynamics.  The  multi-input 
multi-output  (MIMO)  nature  of  flight  dynamics,  which  severely  taxed  the  methods 
of  classical  control  design,  and  the  fiscal  resources  available  as  a  consequence  of  the 
industry’s  vitality,  fueled  the  development  of  the  tools  which  for  the  moment  are  re¬ 
ferred  to  as  “Modern  Control.”  Included  in  the  list  of  the  most  recent  tools  available 
to  the  controls  designer  are  controllers  which  are  designed  through  the  solution  of 
convex  optimization  problems.  The  first  general  objective  of  this  research  was  to 
demonstrate  a  methodology  of  how  these  theoretical  advances  can  be  implemented  in 
aeronautical  applications. 

The  second  phase  of  the  research  tlien  built  upon  the  first,  and  capitalized  on 
the  very  recent  convergence  of  several  technologies.  As  suggested  above,  the  pursuit 
for  performance  has  led  both  the  commercial  and  military  aircraft  industries  into 
the  realm  of  Relaxed  Static  Stability  (RSS)  aircraft.  The  benefits  include  enhanced 
maneuverability,  lower  drag,  lower  weight,  f^nd  lower  cost.  Reduced  static  stability 
is  achieved,  in  large  part,  by  shrinking  or  eliminating  surfaces  or  physical  features 
whose  sole  purpose  is  to  provide  either  control  power  or  static  stability.  Consider- 
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able  industry  and  government  attention  has  been  focused  on  the  question  of  how 
one  quantifies  the  thresholds  for  satisfactory  dynamic  performance.  A  dramatic  re¬ 
vision  to  the  traditional  flying  qualities  specifications,  from  MIL-8785C  [Ref.  1]  to 
MIL- 1797  [Ref.  2]  was  principally  in  response  to  these  types  of  issues.  An  ongoing 
NASA/Navy  research  effort  has  for  several  years  been  trying  to  quantify  thresholds 
and  metrics  for  satisfactory  dynamic  response  [Ref.  3,  4].  Note,  however,  that  the 
focus  has  been  establishing  metrics  for  satisfactory  flying  qualities  (the  dynamic  be¬ 
havior  observed  by  the  aircrew).  One  published  research  effort  (not  associated  with 
a  specific  airframe)  has  concentrated  on  the  task  of  translating  the  flying  qualities 
requirements  into  the  domain  of  vehicle  and  controls  design  [Ref.  5].  In  this  1987 
study,  the  absence  of  both  an  appropriate  theoretical  framework  and  the  requisite  op¬ 
timization  tools  constrained  the  controls  design  approach  to  classical  methods.  The 
very  recent  convergence  of  three  key  technologies:  ( 1 )  the  theoretical  formulation  of 
many  controls  problems  as  convex  or  affine  optimization  problems,  (2)  the  develop¬ 
ment  of  efficient  numerical  methods  for  the  solution  of  convex  or  affine  optimization 
problems,  and  (3)  the  computational  capacity  of  modern  engineering  workstations  to 
execute  such  routines,  now  permits  the  formulation  of  these  vehicle  and  controller 
design  problems  to  be  posed  as  tractable  constrained  optimization  problems.  This 
report  proposes  a  theoretical  formulation  and  demonstrates  a  methodology  by  which 
not  only  a  vehicle’s  control  system,  but  the  physical  configuration  of  the  vehicle  itself, 
may  be  posed  as  a  tractable  constrained  optimization  problem. 

In  the  pursuit  of  the  above  general  objectives,  the  research  effort  was  comprised 
of  three  projects.  The  first  involved  simply  the  use  of  available  commercial  designs 
tools.  The  second  involved  the  creation  of  controller  design  tools  based  on  recent  the¬ 
oretical  formulations,  and  then  their  application  to  a  simple  design  problem.  Finally, 
the  third  area,  the  optimization  of  vehicle  control  power  characteristics  required  the 
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development  of  a  theoretical  formulation,  the  creation  of  the  appropriate  design  tools, 
and  then  their  application  to  simple  design  examples  to  illustrate  the  viability  of  the 
methodology.  Though  these  three  efforts  may  only  seem  loosely  related,  each  of  the 
first  two  projects  had  elements  which  were  critical  to  the  subsequent  project(s).  The 
next  section  provides  an  overview  of  each  project  and  its  specific  objectives. 

A.  SPECIFIC  OBJECTIVES 

The  first  problem  was  pure  Hoo  design  for  the  autoland  control  system  of  a 
l'-14  aircraft.  The  F-14  is  a  carrier-based  fighter  manufactured  by  Grumman  Corpo¬ 
ration,  and  was  selected  for  various  examples  within  this  study  because  of  the  unique 
configuration  of  its  control  surfaces.  This  effort  had  several  specific  objectives: 

1.  Investigate  how  Woo  control  could  be  utilized  to  incorporate  the  F-14’s  Direct 
Lift  Control  (DLC)  in  the  autoland  problem.  DLC  is  a  powerful  aerodynamic 
control  surface  which  can  directly  decrease  or  increase  the  lift  generated  by  the 
wing  by  the  symmetric  deflection/  retraction  of  over-wing  spoilers.  The  DLC 
is  currently  dormant  in  the  F-14’s  autoland  configuration. 

2.  Further  develop  and  demonstrate  a  methodology  whereby  scalar  weighting  func¬ 
tions  could  be  u.sed  to  tune  an  Woo  controller  to  meet  classical  performance 
requirements,  including  sensor  bandwidths.  This  was  an  extension  of  the  work 
of  other  authors  [Ref.  6,  7,  8,  9,  10). 

3.  Introduce  a  methodology  for  the  robustness  analysis  of  nonlinear  air  vehicles. 

The  design  and  analysis  tools  used  here  were  commercially  available,  and  the  principal 
contribution  of  this  section  was  the  demonstration  of  a  methodology  for  their  use. 
Though  convex  methods  were  not  a|)plied  in  this  problem,  the  development  of  tlie 
methodology  was  necessary  as  a  foundation  for  the  second  problem. 


3 


The  second  phase  of  the  work  was  a  mixed  Hi  /  Hoo  controller  design  example. 
Again  the  F-14  autoland  controller  design  problem  was  chosen.  The  objectives  of  this 
phase  included: 

1 .  Development  of  the  computational  design  tools  which  could  solve  the  continuous 
and  discrete  time  H2  J  Hex,  controller  design  problem.  These  problems  had 
previously  been  theoretically  posed  by  Rotea,  Khargonekar,  and  Kaminer  as 
convex  optimization  problems  [Ref.  11,  12). 

2.  Demonstrate  a  methodology  for  the  use  of  mixed  H2  /  Hoo  controllers.  It 
was  assumed  at  the  outset  that  the  methodology  would  be  a  derivative  of  the 
methodology  demonstrated  in  the  first  design  problem. 

This  phase  of  the  work  provided  the  modeling  skills  and  convex  optimization  skills 
which  were  necessary  for  the  pursuit  of  the  final  phase  of  the  research. 

With  the  first  two  projects  complete,  the  foundations  were  in  place  to  pursue 
the  principal  objective.  The  appropriate  sizing  of  aerodynamic  control  surfaces  is 
a  current  issue  as  the  result  of  the  trend  towards  Relaxed  Static  Stability  (RSS) 
aircraft.  The  methodology  in  practice  today  is  for  the  aerodynamic  configuration 
designer  to  provide  a  controls  designer  with  a  configuration  for  which  he  is  to  design 
a  controller  that  will  hopefully  satisfy  the  specified  open-loop  and  closed-loop  perfor¬ 
mance  requirements.  The  controls  designer  only  influences  the  configuration  in  the 
sense  that  if  there  is  inadequate  control  power  to  achieve  the  desired  flying  qualities, 
the  design  is  sent  back  to  the  configuration  designer  to  provide  more  control  power. 
Absent  is  a  method  by  which  the  performance  requirements  can  directly  be  trans¬ 
lated  into  an  optimal  configuration  along  with  an  accompanying  feasible  controller. 
Given  that  many  common  performance  specifications  are  convex,  the  question  posed 
was:  “Is  it  possible,  to  formulate  a  convex  controller  design  problem  in  which  not 
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just  the  controller,  but  the  plant  itself  is  optimized?”  We  will  refer  to  this  as  the 
plant/controller  optimization  problem.  The  final  phase  of  the  research  consequently 
had  three  objectives: 

1.  Determine  a  theoretical  formulation  for  the  plant/controller  optimization  prob¬ 
lem. 

2.  Design  the  computational  tools  necessary  to  implement  the  proposed  solution. 

3.  Create  multiple  design  examples  to  illustrate  and  validate  the  proposed  solution. 

B.  REPORT  ORGANIZATION 

The  report  is  organized  so  as  to  separate  the  discussion  of  computation  issues 
from  the  engineering  issues.  Consequently,  the  main  body  of  the  report  exclusively 
discusses  either  theoretical  issues  or  their  applications.  The  computer  codes  and  their 
relevant  discussions  are  then  found  in  the  various  appendices. 

The  main  body  begins  with  an  overview  of  the  tools  and  theory  which  were 
then  applied  in  pursuit  of  the  above  objectives.  Chapter  II  presents  a  short  discus¬ 
sion  of  convex  optimization,  and  outlines  the  two  numerical  algorithms  which  were 
used  to  solve  the  convex  optimization  problems  which  occur  in  the  report.  Chapter 
III  then  presents  the  theoretical  controls  background  upon  which  the  research  drew. 
Most  important  is  the  outline  of  convex  and  affine  expressions  for  various  control 
design  problems.  Becau.se  of  the  similarity  of  the  two  problems.  Chapter  IV  presents 
the  details  of  both  the  'Ho©  and  mixed  /  Ti^o  design  problems.  This  includes 
a  description  of  the  problem  to  be  .solved,  and  the  methodology  for  both  the  syn¬ 
thesis  and  analysis  of  the  resulting  controllers.  In  both  ca.ses,  a  simulation  exercise 
was  performed  to  verify  that  the  controller  demonstrated  the  desired  characteristics. 
Chapter  V  then  presents  a  methodology  by  which  the  plant/controller  optimization 
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problem  can  be  formulated  as  Linear  Matrix  Inequalities  (LMI’s).  This  formulation 
then  permits  the  solution  of  the  problem  by  convex  methods.  This  chapter  also  in¬ 
cludes  a  number  of  examples  demonstrating  how  various  types  of  specifications  can 
be  accommodated  by  this  methodology.  Finally,  Chapter  VI  provides  a  summary  of 
the  conclusions  and  recommendations  of  the  report. 

The  appendices  form  the  balance  of  the  report  and  include  the  final  versions 
of  the  various  computer  codes  used  to  generate  the  results  found  in  the  main  body. 
MATLAB  was  used  for  all  the  programming,  and  so  the  codes  are  written  either 
ais  function  files,  or  m-file  scripts.  Appendix  A  presents  the  derivation  and  listing 
of  the  codes  which  were  used  to  solve  the  continuous  and  discrete  time  /  'Hoc 
controller  design  problems.  Appendix  B  provides  the  materials  which  supported  the 
two  F-14  design  example  problems.  This  includes  the  SIMULINK  models  used  both 
to  form  the  synthesis  model  and  perform  the  nonlinear  simulation.  The  scripts  used 
to  perform/analyze  the  design  are  also  listed.  Next,  Appendix  C  presents  a  listing  of 
the  interior  point  codes  which  were  used  to  solve  those  problems  posed  as  LMI’s.  The 
original  versions  of  these  codes  were  written  at  the  University  of  Michigan,  and  were 
provided  by  Professor  Pramod  Khargonekar.  They  were  then  substantially  modified 
by  this  author  to  improve  their  numerical  efficiency  and  reliability.  Finally,  Appendix 
D  presents  the  function  files  and  scripts  which  were  used  to  support  and  illustrate 
the  plant/controller  optimization  material  of  Chapter  V. 
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II.  CONVEX  OPTIMIZATION 


This  chapter  provides  essential  background  material  on  the  general  classes  of 
problems  which  were  considered,  and  outlines  the  tools  available  for  solving  these 
problems.  The  first  section  reviews  the  foundational  mathematical  definitions.  Fa¬ 
miliarity  with  these  terms  and  relationships  is  a  prerequisite,  as  they  occur  repeatedly 
throughout  the  report,  and  in  part  define  the  scope  of  this  report.  Next,  the  second 
section  provides  a  brief  overview  of  the  two  numerical  tools  which  were  applied  in 
solving  the  various  example  problems. 

The  following  notational  conventions  will  be  observed  in  this  report.  Greek 
letters  represent  scalars  or  scalar  valued  functions  (e.g.  A  €  R  or  <^(x)  :  R"  — >  R). 
Lower  case  letters  represent  vectors  (e.g.  x  €  R"),  with  a  subscript  i  indicating 
the  ith  element.  Lastly,  uppercase  letters  represent  either  matrices  or  matrix  valued 
functions  (e.g.  Y  €  R"’*"*  or  F{x).  Pairs  of  subscripts  on  a  matrix  are  the  indices 
for  a  particular  element  of  the  matrix.  A  single  subscript  on  a  matrix  indicates  a 
particular  matrix  in  a  set  of  matrices.  Additional  notation  will  be  introduced  later, 
when  flight  dynamics  conventions  prevail. 

A.  DEFINITIONS 
1.  General 

In  general,  the  optimization  problems  considered  during  this  research  were 
of  the  form: 

Given  the  vector  space  R",  and  the  scalar  valued  functions  d>{x) :  R”  — »  R 
and  ip{x)  :  R"  —*  R,  find  Xgpt  GR",  such  that  ^(x)  is  minimized,  subject 
to  il>{x)  <  0. 
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The  function  0(i)  is  referred  to  as  the  constraint  function,  and  if  V’(^)  <  0,  then 
s  e  R”  is  referred  to  as  a  feasible  solution.  The  function  ^(i)  is  referred  to  as 
either  the  objectine  function  or  cost  function.  In  practice,  a  (sub)optimal  search 
was  performed  to  find  a  x„tb  GR"  such  that  <l)(x,ub)  —  <i>{xopi)  <  where  1/  was  an 
arbitrarily  small  stopping  criteria. 

The  following  mathematical  definitions  are  important  in  describing  various 
types  of  functionals.  The  definitions  are  extracted  from  [Ref.  13],  but  are  standard 
across  the  literature.  Consider  the  set  X  €  R”. 

Definition  2.1  The  set  X  is  “affine.  ”  if  for  any  t,  x  €X  and  any  A  <=  R,  Ai  -f  (1  — 
X)x  e  X. 

Definition  2.2The  set  X  is  “convex,"  if  for  any  x,  x  €  X  and  any  A  £  [0,1], 
Ax  +  (1  —  A)x  €  X. 

Definition  2.3  The  functional  <^  :  X  — »  R  is  “affine,  ”  if  for  any  x,  x  6  X  and  any 
A  C  R,  <^(Ax  +  (1  —  A)i)  <  A^(x)  +  (1  —  A)<^(x). 

Definition  2AThe  functional  ^  :  X  -+  R  is  “convex,"  if  for  any  x,  .t  €  X  and  any 
A  €  [0, 1],  <^(Ax  +  (1  -  A)x)  <  A<^(x)  +  (1  -  X)<f>{i). 

Definition  2.5The  functional  <t>  on  the  convex  set  X  is  “quasi-convex  ,"  if  for  any 
X,  X  €X  and  any  A  €  [0, 1],  ^(Ax  +  (1  —  A)x)  <  mux{<f>(x),d>{x)). 

The  following  relationships  can  be  deduced  from  the  definitions: 

1 .  an  affine  set  is  convex  , 

2.  an  affine  functional  is  convex  , 

3.  a  convex  functional  is  quasi-convex, 

4.  the  reciprocal  of  an  affine  function  is  affine. 
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The  most  significant  fact  relating  convex  sets  and  (quasi )convex  functionals 
is  that  if  is  (quasi)ccnvex,  and  o  €  R,  then  the  set  X  containing  all  x,  such 
that  rl>(x)  <  Q,  is  convex.  Similarly,  if  is  affine  and  o  6  R,  then  the  set  X 
containing  all  x,  such  that  rl>{x)  <  a,  is  affine.  These  are  referred  to  as  functional 
inequality  specifications.  The  practical  significance  of  quasi-convex  functionals  and 
the  convex  sets  represented  by  a  functional  inequality  specification  is  that  one  is 
guaranteed  to  find  the  global  minimum  of  an  objective  function  to  within  a  numerical 
threshold.  Furthermore,  if  the  set  is  bounded,  then  the  argument  minimizing  the 
objective  function  can  also  be  isolated.  The  advantage  of  convex  functionals  over 
those  that  are  quasi-convex  is  the  facility  with  which  lower  bounds  can  be  computed 
during  the  optimization  process,  resulting  in  straightforward  termination  criteria. 
The  reference  [Ref.  13]  contains  additional  information  on  the  properties  of  convex 
sets  and  functionals,  as  well  as  illustrations  and  alternative  tests  for  convexity.  The 
optimization  problem  described  above  is  a  (quasi )convex  optimization  problem  if  the 
set  satisfying  the  constraining  functional  inequality  specification  is  convex,  and  the 
objective  function  is  (quasi )con vex. 

The  optimization  problem  described  above  prescribed  that  the  constraint 
functional  tl’{x)  be  scalar.  Many  of  the  constraint  functionals  encountered  in  this 
report  will  be  matrix  inequalities  of  the  form:  H{x)  =  H^(x)  <  0.  This  is  math¬ 
ematically  equivalent  to  the  scalar  functional  inequality:  XmaA^i^))  <  0-  Conse¬ 
quently,  we  can  use  the  functional  matrix  inequality  to  notationally  represent  the 
scalar  constraint:  Amor(^(^))  <  0-  Within  all  of  the  numerical  algorithms  applied 
here,  it  is  the  scalar  constraint  that  is  enforced. 

2.  Linear  Matrix  Inequalities 

Consider  the  set  of  square,  symmetric  matrices  Fq,  Fi,. . .  ,Fn,  where  Fi  = 
Fj  €  R”*^”*,  for  all  i. 
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Definition  2.6The  functional  inequality  F{x)  >  0,  x  6R",  w  «  Linear  Matrix  In¬ 
equality  (LMI),  if  it  can  he  posed  in  the  form  F(x)  =  Fq  +  x,F,  >  0. 

Note  that  the  functional  <f>{x)  =  Xmar{  —  F(x))  is  affine.  Consequently,  the  LMI  , 
F{x)  >  0,  represents  an  affine  functional  inequality  specification.  Though  the  above 
mathematical  definition  of  affine  only  pertains  to  scalar  functions,  it  is  extended  it 
to  include  all  matrix-valued  functions  of  the  form  F(x)  =  Fq  +  5Z"=i  x,F,.  In  this 
context,  we  refer  to  F{x)  as  affine  in  x. 

Several  forms  of  optimization  problems  exist  involving  LMI’s.  The  two 
problems  of  interest  here  are  the  Generalized  Eigenvalue  Problem  (GEVP),  and  the 
Eigenvalue  Problem(EVP).  Let  A(x),B{x),  and  be  symmetric  matrix-valued 

affine  functions  of  x.  The  GEVP  is  defined  as  follows: 


Minimize:  A 

Subject  to:  Ai5(a')  -  y4(x)  >  0,  i9(a:)  >  0,  and  C(x)  >  0.  (2.1) 


The  EVP  is  the  simplified  case  where  B(x)  =  7.  The  important  distinction  between 
the  two  classes  of  problems  is  that  the  EVP  is  a  convex  optimization  problem,  while 
the  GEVP  is  quasi-convex  (see  [Ref.  14]). 

3.  Schur  Complements 

The  following  lemma  will  be  very  helpful  in  reformulating  various  matrix 
inequalities. 

Lemma  2.7  (Schur  Complements)Lef  Q,  S,  and  R  be  matrices  of  compatible 
dimensions.  Suppose  Q  =  ,  and  S  =  .  Then  the  following  two  statements  are 

equivalent: 


1. 


Q  R 

Rf  S 


>  0. 


2.  Q>Q,S  >0,  andQ-  RS'^Rf  >  0. 
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Specifically,  Schur  complements  are  the  means  by  which  many  of  the  Riccati 
inequalities  common  to  modern  control  theory  can  be  reformulated  as  LMI’s. 

B.  NUMERICAL  ALGORITHMS  FOR  THE  SOLUTION  OF  CONVEX 
OPTIMIZATION  PROBLEMS 

Two  numerical  algorithms  were  used  to  solve  the  convex  optimization  problems 
of  this  research.  At  the  point  at  which  the  research  was  undertaken,  two  princi¬ 
ple  numerical  tools  were  available  to  pursue  convex  optimization  problems:  Kelly’s 
cutting  plane  methods,  and  the  Ellipsoid  algorithm.  The  Ellipsoid  algorithm  was 
chosen  both  for  it’s  ease  of  implementation,  and  its  attributes  regarding  problem  size. 
Kelly’s  cutting  plane  methods  were  rejected  due  to  a  concern  about  the  growth  of  the 
data  storage  requirements  for  the  size  problems  being  considered.  Shortly  after  the 
implementation  of  the  Ellipsoidal  codes  for  several  problems,  Interior  Point  methods 
began  to  mature  and  receive  substantial  attention  in  the  controls  community.  These 
latter  methods  are  applicable  only  to  those  convex  optimization  problems  which  can 
be  posed  as  LMI’s,  but  are  reputed  to  converge  much  more  quickly  than  the  previous 
methods.  In  each  case.  Professor  Stephen  Boyd  of  Stanford  University  was  the  prin¬ 
cipal  figure  responsible  for  the  popularization  of  these  tools  in  the  context  of  control 
theory  applications. 

This  section  provides  a  brief  discussion  of  both  of  these  methods.  Only  those 
details  relevant  to  our  specific  implementation  are  addressed,  as  both  these  methods 
were  regarded  as  means  to  an  end.  Details  and  convergence  proofs,  as  well  as  further 
references  regarding  the  history  of  these  methods  can  be  found  in  (Ref.  13,  14,  15). 

1.  Ellipsoidal  Algorithm 

The  ellipsoidal  algorithm  is  suitable  for  use  in  all  quasi-convex  optimization 
procedures,  including  LMI’s,  and  is  mathematically  guaranteed  to  find  a  optimum 
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solution  to  within  a  specified  threshold.  First  of  all,  consider  a  problem  in  which 
one  is  simply  trying  to  optimize  an  objective  function  ^(a*)  without  any  constraints. 
(!)onsider  Figure  2.1.  At  each  iteration  k,  the  search  is  characterized  by  a  vector 
.<•**■'*  e  R",  and  an  ellipsoid  centered  about  whose  size  and  orientation  are 
defined  by  the  positive  definite  matrix  €  R"’'"  (the  eigenvalues  of  are  the 
square  of  the  magnitudes  of  the  respective  semi-axes  of  E***,  while  the  eigenvectors 
of  A^**  are  their  orientations).  Assume  that  optimum  point  is  located  within 
and  let  the  gradient  vector  g  be  defined:  g^'‘^  =  If  =  a,  then  <^(x) 

convex  implies  that  (f){x)  >  a  for  all  x  in  that  half  of  E^*'  in  the  direction  of  g^'’\ 
The  optimum  point  must  then  lie  in  the  other  half  of  E**'*,  and  the  half  in  the 
direction  may  be  discarded  from  the  search.  Consequently,  each  iteration  finds  a 
new  ellipsoid  defined  by  A**‘*‘‘*),  which  completely  contains  the  entire  half¬ 

ellipsoid  bounded  by  ((x^*I,  A^*^),  and  the  hyper-plane  orthogonal  to  g^'‘\  in  the  — 
direction  (the  shaded  area  of  Figure  2.1).  The  process  is  then  repeated.  Though  the 
ellipsoid  may  elongate,  the  volume  of  the  ellipsoid  shrinks  at  a  constant  rate  with 
each  iteration,  until  the  optimum  point  is  isolated  to  suitable  precision.  Preferably, 
the  ellipsoid  should  be  initialized  such  that  it  includes  the  optimal  point,  though  it 
is  reportedly  possible  for  the  ellipsoid  to  migrate  to  capture  the  optimal  point  [Ref. 
13). 

This  mechanism  works  equally  well  for  constrained  optimization  problems. 
For  the  constrained  problem,  the  new  ellipsoid  is  used  to  either  further  isolate  the 
feasible  set  defined  by  the  constraint  functional  inequality,  il>(x)  <  0,  or  reduce  the 
cost  function  ^(x).  The  algorithm  progresses  as  follows: 

1.  Evaluate  ^(x^*^). 

2.  If  x^*'^  is  infeasible  (0(x^*'*)  >  0),  then  find  the  gradient  =  |^|  By 
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Figure  2.1:  Graphical  Depiction  of  the  Ellipsoidal  Algorithm 
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eliminating  the  infeasible  half-space  in  the  direction  a  new  smaller  ellipsoid 
is  determined.  Provided  that  the  search  was  initialized  with  a 
feasible  point  in  the  original  ellipsoid,  then  all  feasible  points  in  are 

retained  in 

3.  If  x^*l  is  feasible  (V»(x^*^)  <  0),  then  find  the  gradient  =  f^j  ,*)•  Now  the 
half  space  is  eliminated  for  which  the  objective  function  has  values  greater  than 
(<^(x^*^)),  retaining  in  (x^*‘‘'*\ /l^*'*’**)  all  of  the  feasible  points  having  objective 
values  less  than  (^(x^*^)). 

4.  Next  iteration 

Note  that  any  number  of  constraint  functions  ^,(x)  could  be  considered  sequentially 
in  step  2  above.  This  structure  is  clearly  apparent  in  the  ellipsoidal  codes  in  Appendix 
A  (such  as  h2inf  syn). 

The  various  formulae  for  updating  the  ellipsoid  can  be  found  in  the  codes 
and  in  [Ref.  13].  The  principal  challenge  in  applying  ellipsoidal  methods  was  the 
derivation  of  the  appropriate  subgradients  of  functions  which  were  not  strictly  differ¬ 
entiable. 

In  practice,  a  deep-cut  modification  to  the  above  algorithm  was  used  [Ref. 
13].  The  principal  here  was  to  use  the  value  >  0  to  shift  the  position  of  the 

hyper-plane  in  the  —5^*^  direction  so  as  to  reject  more  of  the  infeasible  space  with 
each  iteration,  improving  the  speed  of  convergence. 

2.  Interior  Point  Methods 

Interior  point  methods  for  the  efficient  numerical  solution  of  LMI’s  are 
generally  attributed  to  Nesterov  and  Nemirovsky  [Ref.  16].  Their  application  to 
problems  of  interest  to  the  controls  community  was  then  popularized  by  Boyd  and  El 
Ghaoui  [Ref.  14,  15]. 
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Unlike  the  Ellipsoidal  algorithm  outlined  above,  the  Interior  Point  algo¬ 
rithm  is  restricted  to  those  optimization  problems  which  can  be  posed  as  LMI’s. 
Computationally,  the  interior  point  methods  are  superior  to  each  of  the  other  meth¬ 
ods  in  part  because  the  search  is  restricted  to  the  feasible  set  (hence  Interior  Point), 
whereas  both  the  Ellipsoidal  and  Cutting-Plane  methods  can  exhaust  tremendous 
amounts  of  computational  energy  on  isolating  the  feasible  set.  Only  a  brief  overview 
of  the  method  is  presented  here,  and  the  reader  is  referred  to  [Ref.  14,  15]  for  more 
thorough  coverage. 

Consider  the  EVP  above.  By  including  A  as  the  first  element  of  the  vector 
X  (i.e.  2-  =  [  A  ]^),  and  letting  c  =  [1,0, . . .  ,0],  the  EVP  can  be  reformulated: 


Minimize:  A  =  c^x 


Subject  to:  F{x)  := 


XI  -  /l(i) 


C(i) 


>  0. 


Let  A^*l  represent  an  upper-bound  on  A  for  iteration  k.  Let  A“p'  represent 
the  optimal  value  of  the  EVP,  s»>ch  that  for  all  A^*))  >  A®'’*,  the  LMl 


AW)-c^x 


F(x) 


>0. 


is  feasible,  i.e.,  there  exists  a  vector  x  satisfying  the  LML  If  we  assume  that  the  LMl 
has  a  bounded  feasible  set,  then  the  function 


=  log  (det  F(x)  ’)  -|-  log  ^ 

has  a  global  minimum  within  the  bounded  set  since  both  terms  are  convex  functions 
of  X.  The  first  term  of  <i>{x)  is  a  boundary  function  because  its  value  goes  to  infinity 
as  the  boundary  of  the  set  {x  :  F(x)  >  0}  is  approached.  It  is  this  property  that  is 
used  to  keep  the  search  within  the  feasible  set.  The  choice  of  boundary  function  is  not 
unique,  and  while  it  is  unusual  to  find  the  determinant  in  a  computational  routine. 
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it  is  used  here  because  both  the  gradient  and  Hessian  of  the  boundary  function  are 
easily  computed,  and  calculation  of  <f>{x)  itself  is  not  required.  The  analytic  center  of 
<p{x,  X)  is  denoted  as  and  defined  by: 

:=  arg  min^  ^log  (det  F(x,  A)"‘)  +  log  •  (2-3) 

The  Interior  Point  method  used  here  is  based  on  the  method  of  centers  and 
is  comprised  of  two  nested  loops.  In  the  inner  loop,  given  A^*^  the  analytic  center 
a-(A(*))  can  be  found  by  Newton’s  method.  In  the  outer  loop,  A^*^  is  decreased  with 
each  iteration,  and  the  search  for  a:*(A<*'+*^)  is  initialized  at  x*(A^*)).  Algorithmically: 


1.  Initialize  the  problem  at  A;  =  0,  with  some  feasible  and  A^“\  such  that: 

A(o))  _ 


>0, 


2.  Update 


(2.4) 


3.  Find  the  analytic  center  by  Newton’s  method. 

4.  Update 

=  i*(A<''+*>),  (2.5) 


5.  Next  k.  Return  to  step  2  until  termination  criteria  satisfied. 

The  variable  0  €  (0, 1)  is  a  computational  parameter,  with  0  typically  small.  Note 

that  the  second  term  of  <i>{x)  in  2.2  is  singular  if  0  =  0.  In  the  outer  loop, 

represents  the  set  of  analytic  centers,  which  is  described  as  the  path  of  centers,  hence 

the  method  is  referred  to  as  the  method  of  centers. 

Define  the  gradient  (g)  and  Hessian  {H)  of  ^  to  be: 

gix)  :=  (a  vector) 

(a  matrix). 

The  following  algorithm  outlines  the  Newton  search  for  the  analytic  center,  z*(A^*^): 
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1.  Initialize  the  Newton  search  with 


2.  Calculate  each  element  of  the  gradient  and  Hessian  of  <t>  at 

+  (2.6) 

(2.7) 

3.  Determine  the  Newton  decrement,  and  the  damping  factor,  a: 

(2.8) 

'  ^  “  \  l/(H-<!)(x<*-'>))  iM(x(''-'))  >  0.25  • 

4.  Update  the  search: 

x<*-'+‘»  =  x(it,  /)  -  q(x<''-'>)//(x<*’'')-‘5(x<*''‘).  (2.10) 


5.  Next  /.  Return  to  step  2,  unless  termination  criteria  satisfied. 

6.  x*(A(*))  =  x<*-'>. 

Details  regarding  the  algorithm,  including  convergence  proofs,  termination  criteria, 
and  modifications,  can  be  found  in  the  above  references.  The  interior  point  routines 
used  for  this  research  are  discussed  and  documented  in  Appendix  C.  It  is  important  to 
note  that  these  routines  are  not  problem  specific  but  are  suitable  for  solving  any  prob¬ 
lem  which  has  been  posed  as  a  GEVP  (EVP).  Once  the  problem  is  so  posed,  then  the 
interior  point  algorithm  requires  only  the  three  sets  of  basis  matrices  {  Ao,  Aj, . . . ,  /4„}, 
{Bo,  fli, . . . ,  Bn},  and  {Co, Ci, . . . ,  C„}. 
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III.  THEORETICAL  BACKGROUND 


A  wide  range  of  interesting  and  powerful  control  problems  can  now  be  solved  and 
applied  as  the  result  of  recent  advances  in  computational  methods,  computer  capacity 
and  theoretical  control.  The  previous  chapter  outlined  several  of  these  computational 
tools.  This  chapter  provides  the  theoretical  background  for  the  control  design  and 
analysis  tools  implemented  in  this  report. 

Consider  the  multiple  input  multiple  output  (MIMO)  feedback  system  depicted 
in  Figure  3.1.  For  the  purposes  of  this  chapter,  we  shall  consider  only  finite  dimen¬ 
sional  linear  time  invariant  systems.  The  general  problem  of  control  design  is:  Given 


Figure  3.1:  Standard-Feedback  Configuration. 

Q  ,  find  C  such  that  the  closed-loop  system  T{Q  ,C  )  is  internally  stable,  and  such  that 
the  output  vector  z  has  some  specified  desirable  character  in  response  to  either  the 
input  vector  w,  or  some  specified  set  of  initial  conditions.  It  has  long  been  recognized 
that  many  traditional  control  problems,  such  as  solutions  to  Lyapunov's  Equation, 
can  be  posed  as  a  convex  optimization  problems.  It  is  only  with  recent  improvements 
in  computational  capacity  (hard  and  soft),  that  these  problems  have  become  numer¬ 
ically  tractable.  Simultaneous  with  the  increase  in  computational  capacity  came  the 
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realization  that  many  other  desirable  control  problems  could  likewise  be  posed  as 
convex  optimization  problems. 

Initially,  this  chapter  outlines  several  control  problems  which  can  be  expressed 
as  convex  optimization  problems.  First,  the  Hoo  control  problem  will  be  defined 
and  discussed.  The  pure  Hoo  problem  can  be  more  rapidly  solved  by  methods  other 
than  convex  optimization,  but  its  convex  forms  allow  for  several  derivative  problems 
of  interest.  Furthermore,  it  is  the  convex  form  that  allows  Hoo  to  be  used  as  the 
foundation  for  solutions  to  the  plant/controller  optimization  problem.  Next,  the 
mixed  H2  /  Hoo  control  problem  (continuous  and  discrete  time)  will  be  discussed  and 
outlined.  Third,  a  convex  constraint  for  closed-loop  pole  locations  will  be  presented. 

After  the  presentation  of  the  control  design  tools,  the  small  gain  theorems  and 
the  structured  singular  value  will  be  discussed.  By  themselves,  these  are  not  design, 
but  robustness  analysis  tools,  and  while  not  explicitly  part  of  the  convex  optimization 
process,  they  can  serve  as  a  guide  in  formulating  a  synthesis  model  to  design  for 
robustness. 

A.  Hoo  CONTROL 

1.  The  00  Norm 

Consider  again  the  feedback  system  depicted  in  Figure  3.1.  Let  Tg^(Q  ,C  ) 
denote  the  closed-loop  transfer  function  matrix  from  the  input  vector  w  of  exogenous 
signals,  to  the  output  vector  z  of  errors.  Then  the  infinity  norm  of  Tg^iG  )  is 
defined  as  the  supremum  over  all  frequencies  of  its  largest  singular  value: 

II  Tg,^(G  X  )  ||oo:=  sup{a(7;,;;(>u;))}. 
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where  <7  denotes  the  maximum  singular  value  of  T.  This  is  an  induced  norm  from  w 
to  2,  which  can  alternatively  be  expressed, 


\\TUQX)\\oo=  sup{||2|l2:|ltn|2<l}. 


An  interesting  physical  interpretation  is  that  ||  Tg^iQ  X)  ||oo  represents  the  peak 
power  gain  from  w  io  z  [Ref.  17): 

l|r..(c-c)iu=sup{^}, 

where: 

/  1 

pow{w)  :=  • 

The  power  interpretation  clearly  illustrates  one  of  the  many  motivations  behind  the 
attention  Hoo  work  has  received  during  the  past  decade.  It  is  this  property  which 
will  be  exploited  later,  as  specifications  abound  where  a  specified  rms  output  level 
is  permitted  for  a  specified  rms  disturbance  input.  For  example,  the  Dryden  model 
of  air  turbulence  specifies  various  levels  of  turbulence  with  rms  amplitudes.  This 
property  of  the  Woo  norm  permits  us  to  pose  many  typical  disturbance  rejection 
specifications  as  Koo  control  problems. 

Consider  the  following  state-space  representation  of  the  closed-loop  system: 


(  X  =  Fx  +  Gw 
I  2  =  Hx  -1-  Jw  ' 


(3.1) 


where  F  is  stable.  It  is  well  known  [Ref.  18)  that  ||  Tz^  ||oo<  7,  if  and  only  if  there 
exists  a  real  symmetric  matrix,  V  >  0,  such  that: 


FY  +  YF'^  -h  {YH'^  +  GJ'^)(j^I  -  JJ'^)-\HY  +  JG^)  -f  GG^  =  0.  (3.2) 


This  Riccati  equation  is  referred  to  as  the  Wo©  analysis  equation. 
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2.  (Sub)Optimal  Hoo  Output-Feedback  Control  by  Riccati  Methods 
The  Hoo  (sub)optimal  control  synthesis  problem  is  to  find,  among  all  con¬ 
trollers  that  yield  a  stable  closed-loop  system,  a  controller  C  that  minimizes  ||  Tz^{Q  ,C)  ||oo- 
Recent  work  [Ref.  18,  19,  20,  21,  22]  has  led  to  a  simple  and  elegant  approach  to  this 
problem. 

Suppose  that  a  continuous  time  state-space  realization  for  the  plant  Q  depicted 
in  Figure  3.1  can  be  written  as 


Q  = 


< 


X 

2 

y 


Ax  -H  B\w  -I-  Bju 
C\x  -1-  D\u 
C2X  -f  D2W 


(3.3) 


Assume  that  (C2,  is  s iabilizable  and  detectable,  that  D\  has  linearly  indepen¬ 

dent  columns,  and  that  Dj  has  linearly  independent  rows.  Recall  that  a  Hamiltonian 
matrix  is  a  matrix  H  of  the  form: 


H  = 


P  R 
Q  -P' 


where  P^Q  and  R  are  real  n  x  n  matrices  with  Q  and  R  symmetric.  If  such  a 
matrix  H  has  no  imaginary  eigenvalues,  then  the  spectral  subspace  \-{H)  spanned 
by  the  generalized  eigenvectors  belonging  to  eigenvalues  lying  in  the  open  left  half- 


plane  is  of  dimension  n.  Let  the  columns  X  J  ^  basis  for  the  subspace 

We  will  say  that  the  Hamiltonian  matrix  H  belongs  to  dom{Ric)  if  H  has 
no  imaginary  eigenvalues,  and  if  .Yi  is  nonsingular.  If  H  belongs  to  dom(Ric),  define 
Ric{H)  :=  A'a.Yf*  =:  X.  It  is  well  known  that  X  is  symmetric,  P  -f  RX  is  stable, 
and  X  satisfies  the  algebraic  Riccati  equation: 


P'X  +  XP  +  XRX  -Q  =  0. 


The  key  mathematical  result  on  Hoo  synthesis  by  Riccati  methods  is  stated  below. 
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Theorem  3.1  Consider  the  system  3.3.  Suppose 


rank  ^  =n  +  rank(D\),  ^s  =  ju>. 

—Cl  lJ\ 


rank  =  n  +  ran^Dj),  Vs  =  ju. 

—  C2  JJ2 


and  let  y  >  0  be  a  given  positive  number.  Define 


_  A-B2iD\D,r^D[C^  r^B,B{-B2{D\D,)-^B!, 
^  ”  -C[{I  -  Dx{D\D,r^D[)Ci  -A'  +  C[Di{D[D,r^B!, 


7.-.^  _  f  c'2(D2D',)-^D2B[  r^c[c^  -  c,{D2D>2)-'C2 
-  _c,(/  -  £)'(D2Di)-‘Z)2)B;  -A  +  B^Dr{D2D2)-^C2 

There  exists  a  stabilizing  controller  C  such  that  ||T'„4;||oo  <  7  «/  and  only  if 

1.  H('y)  €  dom(Ric)  and  Xi'f)  :=  Ric(H{y))  is  positive  semidefinite. 

2.  7(7)  €  dom{Ric)  and  Y(f)  :=  Ric{J{‘y))  is  positive  semidefinite. 

3.  p{X {'][)Y {'y))  <  7^,  where  p  denotes  the  spectral  radius. 

Then  such  a  controller,  C  ,  is  given  by: 


.^1  i  =  +  z^Y.,cyx 

■  \  u  = 


where 


Aoo  :=  A-\-r'‘BiBlX^-B2BjX^-Z^Y,:oClC2 

Zoo  :=  (I-l-^YooXoo)-^. 


Existence  and  computation  of  A'(7)  and  ^(7)  are  standard  matrix  algebra 
problems  that  can  be  solved  using  a  standard  technique  for  solving  Riccati  equations 


22 


based  on  the  real  Schur  decomposition  [Ref.  23].  The  pair  of  Riccati  equations  associ¬ 
ated  with  //(7)  and  J(7)  are  referred  to  as  the  'Hr^  synthesis  equations.  Specifically, 
the  Riccati  equation  associated  with  //(7)  is  the  state-feedback  synthesis  equation, 
while  J('i)  is  associated  with  is  the  'Woo  filtering  equation. 

Commercial  software  is  available  from  several  sources  which  implements 
this  theorem  to  determine  a  suitable  controller  from  the  input  state-space  model 
[Ref.  24].  In  practice,  implementations  of  this  theorem  usually  start  with  an  arbi¬ 
trary  upper  bound  7u  on  the  achievable  performance.  The  theorem  is  then  used  to 
perform  a  binary  search  in  the  interval  [0,  7^]  for  the  optimal  value  of  7.  If  7u  proves 
infeasible,  then  it  can  be  set  arbitrarily  higher.  Once  the  binary  search  has  deter¬ 
mined  a  sufficiently  small  interval  in  which  the  optimal  value  of  7  must  lie,  the  search 
is  stopped  and  a  (sub)optimal  controller  C  is  computed  using  the  right  endpoint  of 
this  interval  for  7  in  the  formulae  above.  Controllers  determined  by  this  means  are 
usually  referred  to  as  the  central  controller.  These  methods  are  not  perfectly  clean 
numerically,  as  in  practice.  A'  and  V  must  be  allowed  to  have  very  small  negative 
eigenvalues. 

3.  State-Feedback  Hoo  Synthesis  by  Convex  Methods 

In  this  section,  extracted  largely  from  [Ref.  25],  we  show  that  the  fractional 
representation  of  memoryless  (i.e.,  static)  state-feedback  controllers,  i.e.  A'  = 
where  Y  >  0,  can  be  used  to  reduce  the  state-feedback  Hoc  control  optimization 
problem  to  a  convex  feasibility  problem  over  the  space  of  finite-dimensional  real  ma¬ 
trices.  This  fractional  representation  was  first  introduced  by  [Ref.  26],  and  will  be 
used  extensively  throughout  this  report. 

In  order  to  introduce  this  parameterization,  we  first  answer  the  following 
question.  Given  a  plant,  Q  ,  with  all  the  states  available  for  feedback,  characterize 
the  set  Am{Q  )  of  all  stabilizing  memoryless  state- feed  back  controllers.  Suppose  the 
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plant  Q  is  represented  by  the  following  equations 

{X  =  Ax  +  Biw  +  BiU 

z  =  C,x  +  D,n  (3.7) 

y  =  a:, 

where  x  £  u  G  R''  and  2  €  R^-  Let  E  denote  the  .set  of  all  real  n  x  n  symmetric 
matrices,  and  define 

n  :=  Y)  €  X  E  :  r  >  0}  (3.8) 

Note  that  n  is  a  strictly  convex  open  subset  of  x  E 
We  now  make  the  following  assumption: 

Al.  The  pair  (^4,^2)  is  stabilizable. 

Assumption  Al  is  necessary  to  guarantee  that  Am{G  )  is  not  empty. 

Theorem  3.2  Let  Q  be  given  by  equation  (3.7).  Define 

L(W,  Y)  :=  AY  +  V'A'  +  B2W  +  W'B'^.  (3.9) 

Consider  the  set 

:={(W,y)€n:L(W,r)<0}. 

Then  AmiG  )  is  nonempty  if  and  only  if  is  nonempty.  In  this  case  is  convex 
and  the  mapping 

y? :  AmiG  ) :  {WAl  ^  WY-^ 

is  onto. 

Proof.  Suppose  A'  €  Am{G  )•  Then  it  follows  from  Liapunov  stability 
theory  that  there  exists  >'  >  0  such  that 

(A  +  BjhlY  +  ^(A  +  BiKy  <  0.  (3.10) 

Set  W  =  h'Y  in  (3.10)  to  get  (3.9). 
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Conversely,  suppose  (W^Y)  €  ^m-  Set  K  =  WY~^  in  (3.9)  to  get  (3.10). 
Finally,  convexity  of  follows  from  the  convexity  of  the  mapping  Y  -* 
L{Y),  which  is  linear  and,  hence,  affine  and  convex.  ■ 

Next,  we  proceed  to  similarly  parametrize  the  set  of  all  memoryless  stabi¬ 
lizing  state-feedback  controllers,  which  also  make  the  infinity  norm  of  the  closed-loop 
transfer  function 

||7'ju;(G,  A')||oo  less  than  a  given  number  7  >  0.  We  denote  this  set  Aoo,m{.Q  )•  The 
importance  of  this  theorem  is  in  the  fact  that  it  parametrizes  Aoo,m{Q  )  in  terms  of  a 
set  of  solutions  to  a  convex  QMI  (quadratic  matrix  inequality). 

Theorem  3.3  Let  Q  be  given  by  equation  (3.7)  and  let  7  >  0.  Define 

R{W,Y)  :=  AY+YA'+B2W+W'B!,MCtY+D^Wy(CiY+DiW)+BiB{/^\  (3.11) 

Consider  the  set 

4>m.oo  :=  {{W,Y)€n:R(W,Y)<0}. 

Then  Aoo,m{G  )  is  nonempty,  if  and  only  if  $m.oo  is  nonempty.  In  this  case  $m,oo  is 
convex  and  the  mapping 

:  ^r.,00  Aoo,m{Q  ) :  (W,  Y)  ^  WY'^ 

is  onto. 

Proof.  Without  loss  of  generality  assume  7  =  1.  Suppose  K  €  Aoo.miQ  )  is 
given.  Then,  it  follows  that  there  exists  F  >  0  such  that  the  Hoc.  analysis  inequality 
3.2  is  satisfied; 

[A  +  B2K)Y  -I-  Y(A  -h  B2K)'  +  V  (C’,  -I-  DJ<yiCi  +  Dil<)Y  +  BiB[  <  0.  (3.12) 

Set  W  =  KY  in  (3.12)  to  get  (3.11) 

Conversely,  suppose  (W,  K)  €  ^>m,oo  are  given.  Set  K  =  WY~^  to  get 
(3.12).  Then  it  follows  that  A'  €  Aoo,m{Q  )• 
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The  convexity  of  $m,oo  is  proved  in  [Ref.  11).  ■ 

By  Schur  complements,  inequality  3.11  is  equivalent  to  the  following  LMI 
[Ref.  15,  20]: 


Ri{W,Y) 


AY-\-YA'-\-B2W-\-W'B!i  +  BxB[  {CY DW)' 
(CY  +  DW)  -72/ 


<0,  (3.13) 


This  LMI  expression  is  superior  to  the  QMI  3.11  in  two  respects.  First  of  all,  it  is 
affine  in  the  controller  parameters  W  and  Y,  Secondly,  the  LMI  is  also  jointly  affine 
in  7^.  Consequently,  while  Riccati  methods  can  only  find  a  controller  for  a  specified 
7,  and  methods  such  as  bi.section  are  required  to  find  the  optimal  7,  convex  methods 
using  the  LMI  expression  can  find  a  (sub)optimal  7  and  associated  controller  directly. 
Similar  expressions  exist  for  the  output  feedback  synthesis  problem  [Ref.  27).  This 
LMI  will  figure  critically  in  our  formulation  of  the  control  power  optimization  problem. 


B.  MIXED  Hi  /  Hoc  CONTROL 

Multi-objective  control,  and  most  specifically,  mixed  Hj  /  Hoo  control  has  re¬ 
ceived  considerable  attention  in  the  controls  literature  in  the  past  several  years  (see 
[Ref,  28,  12])  and  references  therein).  This  section  presents  the  theoretical  results 
which  provide  for  the  convex  solution  of  the  mixed  problem  in  both  continuous  and 
discrete  time  cases.  These  results  are  largely  extracted  from  [Ref.  28,  12]. 

1.  Continuous  Mixed  H2  /  Hoo  Control 

Consider  the  finite-dimensional  linear  time  invariant  (FDLTI)  system  de¬ 
picted  by  Figure  3.2.  The  objective  of  the  underlying  problem  is,  given  Q  ,  find  C  , 
such  that  the  generalized  Hj  cost  of  the  closed-loop  system,  )||2y  is  min¬ 

imized,  subject  to  the  constraint  that  ||rz,u;(P  ,C)||oo<7.  The  generalized  H2  cost 
is  defined  as: 

:=  p  (i  jT  r™(ju,)7’;.(;u.)riu;),  (3,14) 
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Figure  3.2:  The  Hi  /  Hoa  Synthesis  IVamework. 
where  /(•)  can  be  either  1)  the  trace,  2)  the  maximum  eigenvalue ,  or  3)  the  maximum 
diagonal  element.  The  reader  is  referred  to  [Ref.  29]  for  a  discussion  of  the  attributes 
of  these  norms. 

Suppose  Aoo,miG  )  is  nonempty,  i.e.,  a  controller,  C  ,  exists  such  that 
lin,u,(Ci,c)iioc  <  7.  The  set  defined  by  Aoo,m{G  )  is  then  referred  to  as  the  set 
oi  feasible  controllers.  In  [Ref.  28,  30],  the  authors  introduce  an  associated  cost,  the 
mixed  /  Hoc  norm  (||  •  jjj/ooli  which  they  prove  is  an  upper  bound  to  the  gener¬ 
alized  H2  cost.  The  'H2  /  Woo  problem  can  then  be  considered  as  a  search  over  the 
set  of  feasible  controllers  for  that  controller  which  minimizes  llT*ou<(^  X  )||2/oo-  Fur¬ 
thermore,  the  determination  of  a  controller,  C  ,  which  minimizes  (G  X  )||2/oo, 
subject  to  ||T„u,(^  X  )||oo  <  7,  is  posed  as  the  following  convex  optimization  problem. 

Consider  the  following  state-space  representation  of  the  closed-loop  system 
i'zwlG  X  )»  where  C  is  feasible: 

{X  =  Fx  +  Gw 

zo  =  Hox  +  Jqw  (3.15) 

zi  =  Hix J\w 

We  know  from  equation  3.2  that  there  exists  a  unique  symmetric  matrix  V’,  such  that: 

FY  +  YF'^  -H  (YHl  +  GJj)(-iU  -  J^Jjy^HiY  -h  =  0. 

Moreover,  if  Lc  is  the  controllability  Grammian  of  the  pair  (F,G),  then  0  <  Lc  <  Y. 
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The  generalized  mixed  'H2  /  Hoo  cost  of  the  closed  loop  system  is  then  defined  as: 


J  00  if  Jo  0 
\  /{HoYHq)  otherwise 


(3.16) 


Consider  now  the  following  state-space  representation  of  Q  : 

X  =  Ax  +  Biw  +  B2U 
Q  ^  ^0  =  Coix  +  Do\u 

=  C\ix  +  Di\u 
,  y  =  C2X  +  D2\tv 


(3.17) 


Let  n  :=  d2m(x),  and  m  :=  dtm(u).  Furthermore,  assume  that:  (a)  the  triple 


{C2iA,B2)  is  stabilizable  and  detectable,  (b)  the  pair  {A,B\)  has  no  uncontrollable 
modes  on  the  imaginary  axis,  and  (c)  D2i[Bl  ZJji]  =  (0  /]. 

Suppose  there  exists  a  symmetric  matrix  Q  >  0,  satisfying  the  Hoo  filter¬ 


ing  equation: 


AQ  +  QA'^  +  QiClCx  -  CJC2)Q  +  B^Bj  =  0. 


(3.18) 


Define  the  auxiliary  quantities: 


Aq  =  a  A"  QOi^Ci  B\q  :=  QCj  B2Q  :=  B2  +  QCj D\\ 

Let  {W,Y)  £  {W,Y  :  W  £  >  0}.  Finally,  define: 

R{W,Y)  :=  AqYA-YAIa-B2qW  +  W'^BJq  +  BxqB,\Q'^  + 

(CiY  +  DnWfiCiY  A-  D12W)  (3.19) 

M{W,Y)  :=  CoQC^  A-{CoYA-Do2W)Y-^iCoYA-Do2Wf.  (3.20) 


Note  that  equation  3.19  is  identical  to  3.11. 

Let  ^  define  the  set  of  feasible  solutions: 

:=  {(IF,^)  :Y  =  Y'^  >  0,R(W,Y)  <  o},  (3.21) 

and  consider  the  optimization  problem 


af  ;=  \nf  {f{M{W,Y)) :  (H^,^)  €  .  (3.22) 
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Theorem  3.4  The  set  of  feasible  controllers,  A<x,.m(G  ),  is  not  empty,  if  and  only  if: 

(1)  A  stabilizing  solution  Q  >0  exists  to  3.18,  and  (2)  the  set  $  is  not  empty.  If  a 
feasible  controller  exists,  then 

JjiT.ou>(Q  X  ))  :=  f(M(W,Y)). 

Moreover,  given  any  a  >  <Tj,  there  exists  a  solution  ,  ( W,  y)  €  ^  such  that  f(M{W,  Y))  < 

a,  and  the  dynamic  observer  based  controller 

^  ^  +  BiQU  +  Bxqiy  -  Cii) 

^  \  u  =  WY-^i  ^ 

/.s  feasible  and  JjiTg^wiQ  ))  <  o. 

Consequently,  if  a  feasible  controller  exists,  then  the  problem  of  finding  a 
(sub)  optimal  controller  for  the  'H'l  /  'Hoc  problem  can  be  reduced  to  the  solution 
of  a  Riccati  equation  (3.18),  and  the  numerical  solution  to  the  convex  optimization 
problem: 

Minimize:  fiMiW,Y')),  over  (M^,^)  €  R”***"  x  R”*". 

Subject  to:  R(Vr,>')  <  0,  and  Y  =  Y'^  >  0. 

The  solution  to  the  state-feedback  problem  (C2  =  I,  ^21  =  0)  can  be  simply  posed 
by  eliminating  consideration  of  the  filtering  equation  (3.18),  and  replacing  Aq  =  A, 
B\q  =  B\,  and  B^q  =  B2  in  the  expressions  for  R{W,Y)  and  M(W,  Y)  above.  The 
controller  is  then  C  =  Ktjh  =  WY'~^ . 

The  ellipsoidal  method  was  chosen  to  code  a  MATLAB  function  file  which 
solved  the  state-feedback  design  problem.  A  second  routine  was  also  written  which 
solved  the  measurement-feedback  problem  by  solving  the  filtering  equation  (3.18)  by 
Riccati  methods,  replacing  the  state-feedback  variables  with  the  appropriate  auxiliary 
plant  variables,  and  then  calling  the  state-feedback  design  function.  Both  of  these 
codes  and  their  supporting  subroutines  are  developed  and  then  outlined  in  Appendix 
A. 
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It  is  a  straightforward  matter  to  use  Schur  complements  to  pose  each  of  the 
above  matrix  valued  inequalities,  3.19  and  3.20  as  LMI’s.  Consequently,  the  numerical 
problem  could  also  have  been  solved  by  the  interior  point  method. 

2.  Discrete  Mixed  /  Woo  Control 

This  section  presents  the  theoretical  results  of  [Ref.  12],  which  pose  the 
discrete  H2  /  Wo©  controller  design  problem  as  a  convex  optimization  problem.  The 
discrete  time  H2  /  Wo©  problem  differs  only  slightly  from  the  continuous  time  problem 
above.  The  most  significant  difference  is  that  it  is  structured  about  full-information 
feedback  for  an  auxiliary  plant  rather  than  a  state-feedback  solution. 

First  of  all,  the  definitions  of  the  respective  norms  are  predictably  similar 
to  their  continuous  time  counterparts.  The  discrete  time  version  of  the  generalized 

H2  norm  is:  _ 

l|r..„l|j/;  ~  ^ M).  (3.24) 

where  the  function  /(•)  is  again  either  the  trace  function,  the  maximum  eigenvalue 
(Amai  )i  or  the  maximum  diagonal  entry  (dmor)-  The  W©©  norm  in  discrete  time  can 
be  defined  as: 


IIT’zu-llo©  :=  max 

^€[0  2n] 


(3.25) 


where  denotes  the  maximum  singular  value. 

Suppose  the  plant,  Q  ,  in  Figure  3.2  is  now  represented  by  the  following 
discrete  time  state-space  model: 


G  := 


< 


ax 

20 

y 


=  Ax  B\xv  +  B2U 
=  Cqx  +  Do\w+  D02X1 
=  Cf\x  -|-  Di\to  -|- 
=  C2X:  +  D2\X0, 


(3.26) 


where  a  denotes  the  shift  operator  (<7x)(A:)  :=  x(k  -b  1).  Assume  that  (1)  the  triple 
(C2,  A,  B2)  is  stabilizable  and  detectable,  and  (2)  given  any  complex  number  ^  satis- 
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fyilig  |rl  =  1,  the  matrix 


A-zI  5, 

.  C2  D21  ’ 

has  full  row  rank.  The  solution  to  the  output  feedback  problem  makes  use  of  a 
suitably  constructed  optimization  problem  defined  next. 

Suppose  a  feasible  controller  exists  such  that  HTtiu/Hoo  <  !•  Then,  it  follows 
from  [Ref.  31]  that  there  exists  a  (unique)  real  symmetric  matrix  Q  >  Q  such  that 
the  matrices  V  and  R  defined  by 

1/  :=  C2QCJaD2iDI,  (3.27) 

R  :=  7-D„Df, -C,QC/’  + 

{CxQCj  +  DuDl)V-^{C,QCj  +  DuDlf,  (3.28) 


are  positive  definite.  Moreover,  Q  satisfies  the  following  discrete  algebraic  Riccati 
equation: 


Q  =  AQA'^  +  B,Bl- 


C2QA'^  +  D2xBJ 
C^QA'ADuBJ 


PiQr 


C2QA^  +  D2iBl 
CiQA^-\-DuBl  ’ 


(3.29) 


where 


P(Q)  := 


D21D21  7^21 

1 

[C2I 

D\\D2\  DuD\^  —  I 

c,. 

Q[CI  C’D, 


and  the  matrix 


A- 


C2QA'^  +  D2iBl  ■ 

i 

C2' 

CxQA'^  +  DuBl 

P{Q) 

(3.30) 


is  asymptotically  stable.  This  is  the  discrete  time  analog  of  the  continuous  time 
filtering  equation  expressed  by  ^(7)  in  Theorem  3.1.  With  this  matrix  Q,  define  the 
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following  matrices 


Z  :=  AQCl  +  B,Dj,  -  +  D21DJ,) 

Aq  :=  A  -f  ZR~^C\ 

Bi,q  :=  {AQCj+BiDj,)V-^f^  +  ZR-^{C,QCj  +  DuDDV^^^ 
B2,q  ’=  B2  +  ZR~^  D\2 
C  ’=  c 

Dou  ■=  (DoiDl  +  CoQCj)V-^f^ 

^02, q  ■=  Do2 
C,,q  :=  R-^I^C, 

Dn,q  :=  R-^I^CxQC^  + 

D^2,q  :=  R-^I^Dn^ 

Finally,  define  the  following  matrix  functionals: 


L{W,YJ<2) 


Mq{Q) 

M{W,YJ<2) 


c.  ‘"'1 

B\  +  52A2  1  r  B\  A  ^2^2 
Du  +  D\2l\2  J  [  Du  +  D\2K2 


at'  cj  ■ 

Bl  D^, 
_  [  r  0  ■ 

0  I 


+ 


CqQCq  +  Dq\Dq^  —  Z)oi.iji)oi,9 

Mq{Q)  +  (CoY  +  Dq2W)Y-^(CoY  +  + 


(3.31) 

(3.32) 


{Do\  +  Do2l\2){Do\  +  D02R2V 


(3.33) 


Let  ^  define  the  set  of  feasible  solutions: 

<I>  :=  {(VF,  Y)  :  Y  =  >  0,  L(VF,  V,  A'2)  <  o}  ,  (3.34) 

and  consider  the  optimization  problem 

ffj  :=  \nf{ f{M{W,YJ<2)) :  (W,YJ<2)  €  <!>}.  (3.35) 

Theorem  3.5  The  set  of  feasible  controllers  is  not  empty,  if  and  only  if:  (1)  A 
stabilizing  solution  Q  >  0  exists  that  satisfies  the  conditions  of  (3.27-3.30),  and  (2) 
5^  0.  If  a  feasible  controller  exists,  then 


Jf{T,q,,(g  X  ))  :=  f{M{W,YJ<2)). 
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Moreover,  given  any  a  >  <t/,  there  exists  a  solution  ,  {W,Y,  /vj)  €  ^ ,  and  the  dynamic 
observer-based  controller  (with  input  y  and  output  ti) 


(  axc  =  AtfXc  -f 

C  ^  u  =  AVc 

r,  =  V-‘/2(j,_C2X,) 


(3.36) 


such  that  C  is  feasible  and  Jf{Q  ,C  )  =  f{M{W,  Y,  A'j))  <  a  [Ref.  12]. 

To  solve  the  output  feedback  generalized  'H2  /  'Hoo  control  problem  using 
Theorem  3.5,  the  following  steps  can  be  followed: 


1.  Verify  that  a  feasible  controller  exists;  this  can  be  done  by  solving  two  standard 
Woo  Riccati  equations  [Ref.  31]. 

2.  Perform  the  convex  optimization  problem:  minimize  /(A/(IV,  V',  A'2)),  subject 
to  the  constraints  V  >  0,  and  L(W,  V',  A'2)  <  0. 


3.  Construct  the  output  feedback  controller  C  in  (3.36)  using  the  suboptimal  so¬ 
lution  (W,  V',  A'2)  obtained  in  step  2.  Then,  C  is  feasible  and  J/(G',  C)  <  a;  i.e., 
(3.36)  solves  the  generalized  W2  /  Woo  control  problem. 


As  with  the  continuous  time  problem,  where  the  problem  was  reduced  for 
state-feedback,  the  measurement-feedback  discrete  time  problem  can  be  reduced  for 
any  problem  where  the  states  and  disturbances  are  available  for  feedback.  Consider 
the  following  full-information  plant: 


<71  =  Ax  -f  Biw  +  B^u 
ZO  =  CqX  +  Do\W  -I-  Z?02M 
^ ^  -1  =  C\x  Dww D\2U 

X 


V  = 


XV 


(3.37) 


Though  the  full  information  structure  is  not  realistic  in  applications,  the  solution  to 
this  problem  gives  a  lower  bound  on  achievable  performance  that  rhight  yield  insight 
into  more  complex  output  feedback  problems. 
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The  above  optimization  problem  can  be  reformulated  for  the  full-information 
problem  by  omitting  the  solution  of  the  Riccati  filtering  equation  (3.27-3.30),  omit¬ 
ting  the  formation  of  the  auxiliary  plant,  and  making  the  following  replacements  in  the 
expressions  for  L  and  M:  is  replaced  by  A,  is  replaced  by  Bj,  C,.,  is  replaced 

by  C,,  and  replaced  by  The  optimization  functionals  are  modified  by  setting 
Mg{Q)  =  0.  The  resulting  state-feedback  controller  is  then  C  =  I\,jb  =  \WY~^ ,  A'2). 

The  numerical  routines  which  solve  both  the  full-information  and  measure¬ 
ment  feedback  controller  design  problems  are  outlined  in  Appendix  A.  As  with  the 
continuous  time  problem,  an  ellipsoidal  optimization  routine  was  designed  to  solve 
the  full-information  problem.  This  function  file  could  then  either  be  used  to  solve  a 
full-information  problem  directly,  or  be  called  by  the  measurement-feedback  design 
code  after  the  auxiliary  plant  had  been  posed.  This  problem  could  also  have  been 
solved  by  interior  point  methods,  and  the  LMl  expressions  of  the  matrix  functionals 
can  be  easily  be  determined  by  Schur  complements. 

C.  POLE  PLACEMENT  BY  CONVEX  METHODS 

Pole  placement  is  possibly  the  most  common  metric  used  to  specify  the  per¬ 
formance  of  closed-loop  systems.  The  following  outlines  a  convex  constraint  which 
can  be  used  to  determine  state- feed  back  gains  such  that  a  closed-loop  system  has 
eigenvalues  within  a  specified  circle. 

Consider  the  region  D  defined  by 

D  :=  {z  :  |2  +  9I  <  r,  g  >  r  >  0} .  (3.38) 

It  is  a  disk  in  the  left  half  plane  with  center  (— g,0)  and  radius  r.  Let  a  :=  q  —  r. 
Theorem  3.6  Given  a  state-feedback  gain  matrix  I\  €  the  eigenvalues  of  the 

feedback  interconnection  of  Q  and  C  =  K  lie  within  D  if  and  only  if  there  exists  a 
symmetric  matrix  V''  >  0  such  that  the  following  Quadratic  Matrix  Inequality  (QMI) 
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is  satisfied  [Ref.  32]: 


S  :=  {A  +  BiK +  aI)Y +  Y(A-\- BiK -^alf  + 

(A  +  BjK  +  aI)(Y/r){A  +  BjK  +  alf  <  0.  (3.39) 


By  replacing  K  with  WY~^,  this  expression  is  equivalent  to  the  following  LMI 
by  Schur  complements: 


Sx{W,Y)  := 

'(  {A  +  aI)Y  +  Y{A  +  alf  +  (A  +  aI)(Y/r)(A  +  q/)^+  \ 
B,W({A  +  aI)/r  +  I)'^  +  {{A  +  aI)/r+I)W'^Bf  ) 

(BiWf  -Yr 


<  0. 
(3.40) 


The  set  of  state-feedback  controllers  with  eigenvalues  within  D  is  therefore  convex.  As 
described  in  (Ref.  33],  this  constraint  is  perfectly  suited  for  convex  optimal  control 
problems  where  the  designer  would  like  to  restrict  the  search  to  those  controllers 
whose  eigenvalues  lie  in  a  specified  region. 


D.  ROBUSTNESS  ANALYSIS  BY  STRUCTURED  SINGULAR  VAL¬ 
UES  in) 

This  section  contains  a  description  of  the  principal  tools  used  to  assess  the 
robustness  of  feedback  systems.  In  particular,  we  are  interested  in  the  use  of  the 
structured  singular  value.  The  structured  singular  value  (/«)  was  first  introduced  by 
J.  Doyle  in  [Ref,  34]  and  since  has  proved  to  be  a  valuable  tool  for  the  robustness 
analysis  of  the  closed-loop  systems.  In  this  section  we  briefly  summarize  the  results 
of  [Ref.  34,  35]. 

Consider  the  feedback  system  shown  in  Figure  3.3.  Let  Fi(Q  ,C  )  denote  the 
feedback  interconnection  of  the  plant  Q  and  the  controller  C  and  let  Tg^iQ  )  denote 
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the  corresponding  closed  loop  transfer  function  from  to  to  z  .  It  can  be  shown  that 


Figure  3.3:  Standard  feedback  configuration  with  uncertainty  block. 


any  linear  interconnection  of  plant,  controller,  and  uncertainties  can  be  arranged  to 
match  the  nominal  plant,  Q  ,  having  the  following  form: 


Q  = 


Gn  G*i2 

Gji  G22 


■  A 

Bx 

B2 

Cx 

Dxx 

Dx2 

.  G2 

D2X 

D22  . 

where  (C2,  A,  Bi)  is  stabilizable  and  detectable.  For  stability  analysis,  the  controller 
can  be  absorbed  into  the  nominal  plant  Q  .  The  LFT  (  linear  fractional  transforma¬ 
tion)  representation  of  the  feedback  interconnection  of  the  nominal  plant  G  and  the 
controller  C  is  given  by 


Fi(.Q  X  )  =  Gn  -I-  GuC{I  —  G22C)“'G2i. 

Recall  that  the  Hoo  problem  does  not  explicitly  address  the  issue  of  plant 
uncertainty.  If,  however,  the  plant  uncertainty  is  modeled  as  an  unknown  but  norm- 
bounded,  stable  dynamical  system,  with  the  inputs  and  outputs  of  the  plant  uncer¬ 
tainty  block  included  in  z  and  iv  respectively,  then  Hoo  provides  stability  robustness 
guarantees  as  a  result  of  the  following  theorem: 
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Theorem  3.7  Small  Gain  Theorem  [Ref.  36].  Assume  Fi(Q  ,C  )  is  stable  and  A 
belongs  to  a  set 

BA:={A:A€  TeWoo  , ||A|U  <  I/7}. 

Then  the  feedback  interconnection  of  Fi{QX)  and  A  is  stable  for  all  A  €  BA  if  and 
only  if 

l|7’,.(a,c:)iu  <  7- 

Unfortunately,  Small  Gain  Theorem  can  be  unnecessarily  conservative  when 
applied  either  to  robustness  analysis  or  design.  This  conservatism  can  be  reduced 
by  using  the  extension  of  Small  Gain  Theorem  to  structured  uncertainties.  The 
structured  singular  value  is  the  metric  by  which  this  extension  is  applied.  In  order  to 
define  the  structured  singular  value,  let 

A  =  {diag(Ai,A2, . .  A„)}, 

where  A,’s  are  stable  FDLTI  systems.  Furthermore,  let 

Ac  =  {dia</(A,,A2, . .  A„)}, 

where  each  A,  is  a  complex  matrix. 

Definition  3.8  The  structured  singular  value  fi[M(ju;))  of  the  complex  matrix  M{juf) 
is  defined  as  follows: 

/  0,  i/V  A  €  Ac,  det(/  +  M(iu;)A)  0 
'  I  sup|||A||”'  :  A  €  Ac,^ct(/  +  M{juf)A)  =  0,  |  otherwise. 

The  importance  of  the  structured  singular  value  for  studying  robustness  of  feed¬ 
back  systems  is  due  to  the  following  result  [Ref.  34],  which  characterizes  robust 
stability  of  a  system  in  the  presence  of  stable  structured  uncertainty. 

Theorem  3.9  Let 

RA  =  {A:A€A,1|A|U<  1} 
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Then  the  closed  loop  system  of  Figuit  3.3  is  stable  V  A  €  J3A  if  and  only  if 


MiQ^C)  -.=  sup(/i(F,(g,C))Ou;)<  1 

W 


Applying  this  theorem  as  a  test  for  robustness  is  much  less  conservative  than 
the  small  gain  theorem  itself.  By  restricting  the  set  of  uncertainty  matrices  to  those 
with  the  specified  structure,  a  much  larger  set  of  LFT’s,  F/(^,C),  satisfy  the  stability 
criteria.  In  other  words,  for  structured  uncertainties,  there  is  a  large  set  of  stable 
systems  that  fail  the  criterion  of  the  small  gain  theorem,  and  yet  satisfy  the  latter. 
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IV.  THE  DESIGN  OF  AUTOLAND 
CONTROLLERS  FOR  CARRIER-  BASED  F-14 
AIRCRAFT  BY  AND  Ho  /  METHODS 

A.  INTRODUCTION 

This  chapter  presents  the  results  of  the  application  of  'Woo  and  mixed  W2  /  'Hoo 
synthesis  techniques  to  the  design  of  autoland  controllers  for  a  carrier  based  F-14 
aircraft.  These  efforts  had  several  objectives: 

•  Demonstrate  a  methodology  for  Hoc.  output-feedback  controller  synthesis. 

0  Expand  that  methodology  for  u.se  with  H2  /  Hoc.  synthesis  tools. 

•  Demonstrate  the  use  of  the  H2  /  Woe  synthesis  tools. 

•  Demonstrate  the  feasibility  of  using  Direct  Lift  in  a  multi-variable  autoland 
controller. 

•  Present  a  methodology  for  the  formulation  of  uncertainty  models  based  on  flight 
test  data. 

The  nature  of  the  autoland  controller  problem  and  the  unique  configuration  of  the 
I'- 14,  made  this  problem  ideally  suited  to  these  objectives. 

Carrier  approach  and  landing  is  a  challenging  multivariable  control  problem  in 
which  the  aircraft  states  must  all  be  carefully  controlled  in  order  to  comply  with 
multiple  structural  and  safety-of-flight  constraints.  Automatic  landing  systems  cur¬ 
rently  in  service  on  carrier- ba.sed  aircraft  (including  the  F-14)  incorporate  nested 
single-input/  single-output  (SISO)  controllers,  which  generally  seek  to  regulate  the 
angle-of-attack  with  the  engines  in  the  inner  loop,  while  aerodynamic  surfaces  such 
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as  elevators  or  stabilators  provide  altitude  control.  Sinc<  neither  the  engines  nor  the 
stabilators  can  control  the  altitude  state  directly,  their  influence  is  indirect  through 
a  combination  of  other  states.  The  F-14  has  an  unusual  aerodynamic  configuration 
which  includes  Direct  Lift  Control  (DLC),  thereby  providing  an  aero  surface  with 
substantial  authority  to  control  altitude  directly.  Moreover,  the  DLC  is  driven  by 
actuators  whose  bandwidth  exceeds  that  of  the  other  control  surfaces.  Regrettably, 
this  powerful  control  surface  is  not  used  by  the  automatic  landing  system  currently 
in  service.  In  this  chapter,  two  multivariable  feedback  controllers  are  presented  which 
seeks  to  exploit  this  powerful,  but  dormant  capability. 

To  achieve  this  objective,  the  design  methodology  presented  here  was  developed 
to  enable  the  control  engineer  to  translate  the  design  requirements  into  weighting  func¬ 
tions  for  Hoo  synthesis.  This  methodology  was  then  further  extended  for  use  using 
the  H2  /  Hqo  design  tools.  Most  typical  design  requirements  are  SISO  in  nature, 
whereas  the  Hoo  and  H2  /  Hot,  synthesis  techniques  are  truly  multivariable  tools. 
'I'hus,  the  main  feature  of  this  methodology  is  a  simple  procedure  for  translating 
the  SISO  requirements  into  the  various  weighting  functions  for  Hoc  and  H2  /  Hoo 
synthesis.  Moreover,  once  the  SISO  requirements  have  been  satisfied,  the  Hoo  frame¬ 
work  offers  a  natural  way  to  expand  the  weighting  functions  to  satisfy  multivariable 
stability  and  performance  robustness  requirements. 

This  methodology  has  been  applied  to  the  design  of  control  systems  for  com¬ 
mercial  airplanes,  autonomous  underwater  vehicles  (AUV’s),  flexible  structures  and, 
most  recently,  for  unmanned  aerial  vehicles  (UAV’s),  see  [Ref.  6,  7,  8,  9,  10].  In 
[Ref.  6,  7,  8,  10]  this  technique  was  used  to  synthesize  state- feedback  controllers.  In 
[Ref.  9],  where  a  controller  for  a  flexible  structure  was  designed,  the  methodology 
was  extended  to  include  an  output  feedback  case.  The  methodology  outlined  here 
expands  this  previous  work  to  include  compliance  with  closed-loop  sensor  bandwidth 
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requirements. 

Specifically,  the  methodology  offers  a  simple  and  effective  way  to  design  feedback 
controllers  satisfying  specified: 

•  command-loop  bandwidths, 

•  control-loop  bandwidths, 

•  closed-loop  damping, 

•  closed-loop  sensor  bandwidths. 

Each  of  the  above  objectives  are  pursued  through  a  specific  formulation  of  the  synthe¬ 
sis  model  and  selection  of  the  various  weighting  functions.  Furthermore,  it  has  been 
observed  that  an  additional  benefit  of  this  methodology  is  that  the  resulting  con¬ 
trollers  do  not  cancel  the  undesirable  modes  of  the  open-loop  plant.  This  is  attributed 
to  the  suitable  choice  of  weights  to  satisfy  the  closed-loop  damping  requirement. 

The  appeal  of  this  methodology  is  that  the  control  designer  is  provided  with  a 
straightforward  framework  in  which  to  implement  Hoo  or  X2  /  'Woo  controllers  in 
pursuit  of  typical  design  requirements  without  a  detailed  understanding  of  the  the¬ 
oretical  basis  for  these  tools.  Moreover,  the  results  of  the  design  effort  are  assessed 
using  familiar  SISO  figures-of- merit.  The  availability  of  good  commercial  software 
utilities,  and  ever-improving  computational  resources  only  enhance  the  viability  of  it¬ 
erative  design  methods  such  as  the  one  presented  here.  This  methodology  is  suggested 
as  one  means  of  placing  these  tools  into  the  hands  of  practicing  control  designers. 

The  controller  design  methodology  we  propose  necessarily  has  a  heuristic  com¬ 
ponent.  This  heuristic  component  has  been  influenced  by  our  experience  in  solving 
the  practical  problems  mentioned  above.  Although  we  were  successful  in  applying 
these  design  methodologies  to  this  problem,  we  cannot  offer  any  guarantees  as  to 
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whether  their  application  to  an  arbitrary  control  problem  will  yield  a  satisfactory 
solution. 

Additionally,  a  method  is  proposed  for  accommodating  structured  model  un¬ 
certainty  in  flight  dynamics  problems.  Specifically,  in  using  models  extracted  from 
flight  test  data,  the  uncertainty  in  the  total  value  of  lift,  drag  and  pitching  moment 
may  be  less  than  the  uncertainties  i  individual  stability  derivatives.  For  this  type 
of  data,  a  method  is  proposed  that  considers  the  total  uncertainties  in  t  hese  forces 
and  moments  rather  than  the  uncertainty  introduced  by  each  term  of  the  model. 
The  robustness  of  the  resulting  closed-loop  nonlinear  system  is  then  analyzed  using 
established  structured  singular  value  methods. 

This  chapter  is  organized  as  follows.  Section  B  contains  the  material  relevant 
to  both  controller  design  problems.  This  includes  a  description  of  the  the  carrier 
landing  problem  and  the  design  requirements.  It  also  includes  the  details  of  the 
uncertainty  modeling  process  which  was  used  to  analyze  the  robustness  of  the  closed- 
loop  systems.  Section  C  presents  the  details  of  the  Hoo  controller  design  process, 
the  implementation  of  the  controller  on  the  nonlinear  system,  and  the  analysis  of  the 
resulting  closed-loop  nonlinear  system.  Section  D  presents  the  details  of  the  mixed 
'Hi  /  'Hoo  controller  design  process,  as  well  as  the  analysis  of  the  resulting  closed-loop 
system.  A  comparison  of  the  two  design  methods  and  some  concluding  remarks  are 
then  included  in  sections  E  and  F. 

B.  PROBLEM  STATEMENT 

The  objective  of  the  controller  design  is  to  provide  for  precise  automatic  control 
of  the  approach  and  landing  of  a  carrier- ba.sed  aircraft  in  the  vertical  and  longitudi¬ 
nal  axes.  In  this  section  we  describe  both  the  plant  to  be  controlled  and  the  desired 
performance  specifications.  These  specifications  are  classical  in  nature,  and  are  rep- 
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reseiitative  of  those  posed  to  control  designers  in  industry.  The  notational  convention 
adapted  in  this  chapter  was  to  use  uppercase  letters  to  denote  total  values  of  the  vari¬ 
ables  introduced,  while  lower  case  letters  denoted  the  perturbations  of  these  variables 
around  their  nominal  trim  values. 

1.  Airplane  and  Model  Description 

The  design  problem  to  be  solved  here  deals  with  the  longitudinal  motion  of 
a  fighter  airplane  and  the  control  of  the  longitudinal  rigid  body  dynamics  (by  conven¬ 
tion,  longitudinal  flight  mechanics  refers  to  the  motion  in  the  2-D  plane  spanned  by 
the  longitudinal  and  vertical  axes).  A  complete  description  of  an  airplane’s  equations 
of  motion  can  be  found  in  many  available  references.  See,  for  example,  [Ref.  37). 
Consequently,  we  will  not  describe  the  equations  of  motion  in  detail.  Rather,  we  will 
present  a  brief  qualitative  description  of  the  key  features. 

The  longitudinal  equations  of  motion  of  an  airplane  are  described  by  two 
force  equations  (longitudinal  force  Fr  and  vertical  force  F*)  and  one  angular  moment 
eciuation  (pitching  moment  M).  The  state  variable  associated  with  the  Fx  equation 
is  the  forward  velocity  U  (along  airplane’s  body-fixed  x-direction).  The  state  variable 
associated  with  the  Fz  equation  is  the  angle  of  attack  a  (the  angle  between  the  body- 
fixed  .T-direction  and  the  true  total  velocity).  The  state  variable  associated  with  the 
M  equation  is  the  pitch  rate  Q.  The  integral  of  Q  for  a  typical  approach  and  landing 
condition  is  the  pitch  attitude  0  (the  angle  between  the  body  fixed  x-direction  and  the 
horizon).  Other  motion  variables  of  interest  are  the  airplane’s  airspeed  VJ  (generally 
not  aligned  with  the  body-fixed  x-direction),  flight  path  angle  7  (the  angle  between 
Vt  and  the  horizon),  and  airplane’s  altitude  above  sea  level  //.  All  the  angles  used 
here  are  expressed  in  rad,  angle  rates  in  rad/sec,  position  variables  in  ft,  position 
rates  in  fps,  and  accelerations  in  g's. 
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While  the  above  discussion  is  germane  to  the  flight  dynamics  of  all  aircraft, 
the  F-14  has  a  distinctive  aerodynamic  configuration  due  to  environment  in  which 
it  was  designed  to  operate.  Mission  requirements  dictated  a  variable-sweep  wing 
for  low  drag  at  high  speeds,  with  full-span  flaps  and  slats,  for  very  high  lift  at  low 
carrier  take-off  and  landing  speeds.  Control  along  the  longitudinal  axis  is  provided  by 
two  afterburning  turbofan  engines  (Thrust).  Pitch  control  is  provided  by  symmetric 
deflection  of  two  stabilators  (Stab).  In  the  landing  configuration  (gear  down,  wings 
fully  forward,  and  flaps  fully  extended).  Direct  Lift  Control  (DLC)  is  provided  by 
symmetric  deflection  of  wing  mounted  spoilers.  The  neutral  position  of  the  spoilers  is 
approximately  40%  of  full  deflection,  so  as  to  provide  for  both  positive  and  negative 
contributions  to  the  lift. 

For  the  design  study,  the  sensors  available  included  onboard  accelerometers 
and  gyros  which  provide  pitch  attitude  (0),  longitudinal  acceleration  (Ng),  vertical 
acceleration  (A^*),  and  pitch  rate  (Q).  Total  velocity  (Fj),  was  provided  by  the  air¬ 
craft’s  air  data  system.  Lastly,  for  automated  approaches  and  landings,  the  altitude 
{//)  was  determined  by  a  shipboard  tracking  radar. 

The  model  used  for  the  design  process  was  a  linear  model  obtained  from 
a  nonlinear  simulation  built  using  aerodynamic  coefficient  data.  This  simulation 
model  was  nonlinear  in  that  while  the  aerodynamic  derivatives  were  held  constant, 
the  equations  of  motion  included  the  nonlinear  influence  of  airspeed,  gravity,  as  well  as 
the  dynamic  coupling  terms.  The  flight  condition  was  a  nominal  approach  condition 
of  230  /ps,  at  sea  level,  with  a  gross  weight  of  54,000  /bs.  The  linearized  longitudinal 
model  included  five  states:  u,  o,  q,  0  and  h  and  three  control  inputs:  Sstahi  ^Tfcru»< 
and  Sdlci  where  all  the  linear  states  and  inputs  are  small  perturbations  around  the 
nominal  operating  point.  At  this  condition,  the  longitudinal  rigid  body  motion  of 
the  F-14  is  characterized  by  two  second-order  stable  modes,  the  phugoid  and  short 
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I)eriod,  and  an  altitude  integrator.  The  phugoid  involves  perturbations  in  VJ  and  H 
with  nearly  constant  o,  whereas  the  short  period  mode  involves  perturbations  in  a 
and  Q,  with  Vi  and  //  remaining  constant.  The  short  period  mode  had  a  natural 
frequency  of  1.04  radjsec  and  a  damping  ratio  of  0.45.  The  phugoid  had  a  natural 
frequency  of  0.18  radjsec  and  a  damping  ratio  of  0.06.  In  addition  to  the  plants  five 
states,  the  actuators  were  modeled  by  three  first-order  transfer  functions.  These  were 
appended  to  the  control  inputs  and  had  bandwidths  of  20,  2.5  and  50  radjsec  for 
the  stabilators,  engine,  and  DLC,  respectively.  As  a  result  the  complete  system  was 
represented  by  an  eighth  order  linear  model. 

2.  Problem  Description 

The  general  problem  was  to  design  a  feedback  controller  which  would  satisfy 
the  operational  constraints  imposed  by  the  mission.  The  challenge  of  landing  an 
aircraft  at  sea  requires  very  precise  control  of  the  aircraft  states.  Glideslope,  which 
is  the  desired  spatial  trajectory  of  the  aircraft,  must  be  tightly  controlled  to  provide 
for  safety  and  to  achieve  the  precise  touchdown  necessary  to  be  arrested  on  the  ship. 
The  glideslope  is  an  imaginary  ramp  oriented  three  degrees  above  the  horizon,  moving 
with  the  ship  and  terminating  in  the  center  of  the  landing  area.  In  the  case  of  manual 
landings,  deviations  from  glideslope  are  detected  visually  by  the  pilot  with  a  visual 
reference  to  a  shipboard  optical  system.  For  automated  landings,  a  precision  tracking 
radar  onboard  the  ship  compares  the  aircraft’s  position  with  an  internally  calculated 
glideslope,  and  transmits  an  error  signal  to  the  aircraft’s  flight  control  system  via  data 
link.  Tight  control  of  aircraft  total  velocity  is  driven  by  the  competing  requirements 
of  providing  for  adequate  aerodynamic  performance,  while  minimizing  the  kinetic 
energy  that  the  airframe  and  arresting  gear  must  absorb  upon  landing.  Tight  control 
of  the  aircraft  attitude  is  required  to  prevent  tailstrike.  Both  of  these  objectives  can 
be  achieved  by  controlling  angle  of  attack  with  total  velocity  and  the  pitch  attitude 
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as  dependent  variables,  functions  of  the  angle  of  attack.  Angle  of  attack  is  also  an 
attractive  control  variable  as  consistent  aerodynamic  performance  is  achieved  for  wide 
ranges  of  gross  weights. 

The  approach- to- landing  problem  can  be  fully  characterized  by  several 
combinations  of  the  variables  in  the  state  vector  due  to  the  mathematical  and  aero¬ 
dynamic  relationships  between  these  variables.  Likewise  the  control  objectives  can 
be  achieved  by  tracking  any  one  of  these  combinations.  Systems  in  fleet  use  today 
incorporate  nested  SISO  controllers,  with  the  engine  controlling  angle  of  attack  in  the 
inner-loop  and  the  stabilators  controlling  either  sink  rate  or  flight  path.  The  remain¬ 
ing  variables  are  then  dependent  functions  of  the  gross  weight  and  the  two  controlled 
parameters.  In  this  design  example,  we  propose  to  use  DLC  to  provide  independent 
altitude  control  of  F-14  in  approach  and  landing.  Currently  F-14’s  DLC  is  engaged 
for  approach,  such  that  the  spoilers  are  deployed  to  their  neutral  DLC  position.  DLC 
is  not  utilized  as  part  of  the  control  system,  however,  and  serves  only  to  increase  both 
the  drag  and  the  trimmed  power  setting  (this  is  done  in  order  to  keep  the  engines  in  a 
more  responsive  range  of  operation).  Neither  the  engines  nor  the  stabilators  provide 
control  directly  into  the  altitude  state,  but  rather  indirectly  control  the  flight  path/ 
altitude  through  the  airspeed  and  pitch  attitude  states.  Performance  may  thereby  be 
sacrificed,  as  DLC  is  the  only  control  effector  which  has  control  power  directly  into 
altitude  through  the  vertical  velocity,  and  DLC  actuator  is  the  fastest  of  the  three 
available  actuators.  Given  three  independent  control  effectors  with  sufficient  control 
power,  F-14  has  the  resident  capability  to  track  three  independent  command  signals. 
A  multivariable  approach  to  the  control  design  would  permit  inclusion  of  the  DLC 
in  the  control  system  resulting  in  both  an  enhanced  capability  and  an  improvement 
in  performance.  Therefore  our  control  strategy  was  to  track  altitude  (//),  and  angle 
of  attack  (a),  using  stabilators,  engines  and  DLC.  Since  the  number  of  controllers 
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exceeds  the  number  of  command  variables,  the  flexibility  existed  to  wash  out  one  of 
the  controllers.  We  chose  to  wash  out  the  DLC.  The  desired  effect  was  that  the  thrust 
would  control  the  glideslope  in  steady  state,  while  the  DLC  would  provide  dynamic 
glideslope  control.  Thus,  the  design  problem  was  to  synthesize  feedback  controllers 
which  tracked  a  glideslope  signal,  while  controlling  angle  of  attack  in  steady-state, 
given  the  available  sensor  suite. 

3.  Design  Requirements 

In  light  of  the  above,  the  "Woo  controller  was  required  to  satisfy  the  fol¬ 
lowing  design  requirements  outlined  below.  These  requirements  will  later  be  modified 
for  the  mixed  H2  /  H^o  design  example 

1.  Zero  Steady  State  Error 


•  Achieve  zero  steady  state  values  for  all  error  variables  in  response  to  step 
commands  in  angle  of  attack,  and  ramp  commands  in  altitude  (this  was 
necessary  for  glideslope  signal  tracking  and  wind  disturbance  rejection), 
while  washing  out  DLC  in  steady  state. 

2.  Bandwidth  Requirements 

•  The  input-output  command  response  bandwidth  for  all  three  command 
channels  was  to  be  approximately  1  rad/sec. 

•  The  control  loop  bandwidth  was  not  to  exceed  40  radjsec  for  the  DLC 
actuator,  20  radjsec  for  symmetric  stabilator,  and  2  radjsec  for  the  engine. 
These  numbers  represented  80%  of  the  corresponding  actuator  bandwidths 
to  ensure  that  the  actuators  were  not  driven  beyond  their  linear  operating 
range. 
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•  The  sensor  response  band  widths  were  to  be  approximately  100  radfsec  for 
the  gyros,  accelerometers,  and  integrators,  and  approximately  5  radfsec 
for  the  altitude,  angle  of  attack  and  airspeed  data. 

3.  Closed-Loop  Damping 

•  The  closed-loop  eigenvalues  associated  with  physical  states  were  to  have 
the  damping  ratio  of  at  least  0.6.  (This  permits  controller  modes  to  have 
damping  ratios  less  than  0.6). 

4.  Robustness 

•  The  controller  could  not  cancel  the  lightly  damped  open-loop  poles  of  the 
plant 

•  Simultaneous  gain  and  phase  margins  of  ±6dB  and  45  degrees  in  all  control 
and  sensor  loops 

•  Stability  was  to  be  guaranteed  for  simultaneous  variations  of  20%  in  the 
perturbed  lift  and  drag  forces  and  pitching  moment. 

4.  Uncertainty  Modeling 

This  section  describes  the  methodology  used  for  analyzing  robustness  of  the 
closed-loop  system  consisting  of  the  aircraft  model  and  any  controller.  The  aircraft 
model  used  in  this  chapter  was  obtained  from  the  flight  test  data.  As  a  result  some 
of  the  terms  in  the  model  are  poorly  known.  These  terms  include  airplane’s  lift,  drag 
and  pitching  moment.  On  the  other  hand,  terms  such  as  gravity  and  aircraft  dynamic 
coupling  are  known  well.  Furthermore,  lift  and  drag  are  measured  in  the  so-called 
stability  axis,  whereas  the  aircraft  model  was  derived  in  the  body-fixed  coordinate 
system.  These  considerations  indicate  that  the  uncertainties  in  lift,  drag  and  pitching 
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iiioineiil  must  be  modeled  exactly  where  they  occur.  Therefore,  this  should  be  done 
using  aircraft’s  nonlinear  equations  of  motion  while  taking  into  account  the  coordinate 
systems  where  these  forces  and  moments  were  measured  during  the  flight  test.  A 
detailed  discussion  of  this  process  is  given  next. 

Let  X  represent  the  vector  of  the  longitudinal  states  of  the  aircraft: 

I  =  [f/,  a,  Q,  0,  Hf. 

Let  6  represent  the  vector  of  the  aerodynamic  control  effectors,  consisting  of  the 
stabilators  and  DLC,  and  let  F  represent  the  vector  of  body-axis  forces  and  moments: 

Fgravi^)  •=  influence  of  gravity 

Fdyn(^)  •—  influence  of  dynamic  coupling 

Faeroi^)  '=  influence  of  aerodynamic  forces  on  the  body 

Fthrust  :=  influence  of  thrust 

Fi  :=  influence  of  aerodynamic  forces  on  the  control  surfaces. 

Note  that  the  first  three  are  state  dependent,  while  the  last  two  are  functions  of  the 
appropriate  controllers.  The  aircraft  equations  of  motion  can  now  be  expressed  as: 

V  ■ 

Q!  —  F jrav  (^  )  "h  F ign{3  )  -f"  /“  thrust  "I"  F,wh(^  )  {F F[S))  ,  (4.1) 

Q. 

where  Ru,b{x)  is  the  wind  to  body  axis  rotation  matrix: 

—  cos  a  sin  a  0 

=  —sin  a  —  cosQ  0  .  (4.2) 

0  0  1  J 

We  only  consider  uncertainties  in  the  aerodynamic  forces  and  moments, 
since  the  gravity,  dynamic  coupling  and  thrust  are  all  well  known. 
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The  aerodynamic  model  of  the  airplane  is  derived  using  stability  deriva¬ 
tives,  which  represent  the  contribution  of  each  state  and  control  input  to  the  aerody¬ 
namic  forces  and  moments  acting  on  the  airplane.  This  data  can  be  obtained  either 
in  the  wind  tunnel,  where  isolation  of  individual  contributions  is  frequently  possible, 
or  flight  test,  where  only  macroscopic  behavior  is  observed,  and  then  numerically 
distributed  among  the  aircraft’s  states  and  inputs.  The  stability  derivatives  obtained 
from  the  flight  test  data  therefore  depend  upon  very  complex  multivariable  parameter 
identification  (PID)  methods,  which  are  executed  in  two  steps.  First,  forces  and  mo¬ 
ments  are  computed  from  observed  accelerations  and  rates.  Second,  the  PID  process 
tries  to  identify  which  control  inputs  and  airplane  states  contribute  to  the  observed 
change  in  forces  and  moments.  This  step  clearly  introduces  errors  not  present  in  the 
first  computation. 

Our  choice  is  then  to  consider  either  the  contribution  of  the  uncertainty  in 
each  parameter,  or  the  net  uncertainty  in  our  knowledge  of  the  forces  and  moments. 
There  are  several  reasons  to  choose  the  tatter.  First  of  all,  the  size  of  the  uncertainty 
model  is  significantly  reduced.  Secondly,  the  uncertainties  in  each  stability  derivative 
are  not  independent.  If  they  were,  then  large  uncertainties  in  each  stability  derivative 
will  result  in  large  uncertainties  in  the  net  forces  or  moments,  leading  to  an  unnec¬ 
essarily  conservative  design.  Consequently,  we  chose  to  model  the  uncertainty  block, 
A,  as  a  3  X  3  diagonal  matrix,  where  each  diagonal  element  represented  a  percentage 
of  the  nominal  perturbation  in  the  aerodynamic  forces  and  moments  (drag,  lift  and 
pitching  moment).  Incorporating  this  block  in  equation  4.1  yields: 


Q 


=  ^gravix)  +  Fdyni^)  +  F'thruH  +  Rwb{r)(f  +  A)  ( Foero(aO  +  ^(^))  •  (4.3) 


[Ql 

Figure  4.1  depicts  equation  4.3.  Here  .signals  w$  and  denote  the  uncertainty  inputs 
and  outputs. 
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thrust 


Figure  4.1:  Uncertainty  Model 

C.  Hoo  CONTROLLER  DESIGN 

In  this  section,  we  will  describe  the  key  features  of  the  controller  design  process 
which  we  followed.  The  section  is  organized  into  a  number  of  subsections  that  em¬ 
phasize  some  of  the  important  engineering  issues  that  aro.se  in  the  controller  design. 
The  MATLAB  scripts  and  SIMULINK  models  used  to  pose  and  analyze  the  problem 
are  outlined  in  Appendix  C. 

1.  Synthesis  Model 

The  first  step  in  the  controller  design  process  was  the  development  of  the 
synthesis  model  which  served  as  an  interface  between  the  designer  and  the  Hoc 
controller  synthesis  algorithm. 

Consider  the  feedback  system  in  Figure  4.2.  The  synthesis  model  was 
derived  from  the  linear  model  of  the  airplane  by  appending  the  depicted  weights  . 
The  weights  became  the  “knobs”  which  the  designer  adjusted  to  achieve  his  specified 
performance.  Here  C  is  the  controller  to  be  designed,  P  is  the  linear  model  of  the 
F-14  and  the  block  Q  within  the  dotted  line  is  the  synthesis  model.  The  signal  u)j 
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Figure  4.2:  Synthesis  Model 

represents  the  commanded  inputs  which  were  to  be  tracked; 

tO]  =  I  fiemd  ^^cmd  ^emd  j 

The  signal  wj  represented  the  noise  inputs  to  each  of  the  sensors,  and  disturbance 
inputs  to  the  states  of  the  plant.  The  signal  Uc  represented  the  control  inputs  to  the 
system  and  was  composed  of  the  stabilator  command,  the  thrust  command,  and  the 
DLC  command.  The  signals  .tj  and  X2  are: 

xi  =  h  Q  DLC  j  X2=(^uaq9h'j. 

The  signal  e  represented  the  vector  of  the  tracking  errors  (c  =  ujj  —  ti). 

The  outputs  of  14^1,11^2  and  W3  comprised  the  vector  z.  Since  we  required 
zero  steady-state  errors  in  tracking  a  ramp  altitude  command,  and  a  step  q  and  DLC 

commands,  the  weighting  function  W\  was  chosen  to  have  the  following  form: 

/  ^  0  0  \ 

VT,  =  0^0. 

\  0  6  ^  / 
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where  the  constants  ci ,  cj  and  C3  were  adjusted  to  get  the  desired  command  response 
bandwidths.  Thus,  weighs  the  integrators  on  the  regulated  variable  error  channels. 
Furthermore,  it  was  required  to  have  full  rank  in  order  to  satisfy  the  detectability 
assumption  of  Theorem  3.1. 

It  turned  out,  that  unlike  VFi,  W2  and  W3  did  not  need  to  include  any 
dynamics.  The  choice  for  the  weighting  function  W2  was: 


W2 


^  C4  0  0 

0  C5  0 

0  0  C6 


where  C4,  C5,  and  ce  were  adjusted  to  achieve  the  desired  control  loop  bandwidths; 
1'F2  was  also  required  have  full  rank  in  order  to  satisfy  the  full  rank  assumption  of 
Theorem  3.1. 

Next,  the  reader  will  note  that  the  elements  of  the  vector  X2  rate 

terms  on  the  principal  states  of  the  plant.  Selection  of  X2  is  an  important  element 
of  our  methodology.  Applying  the  weight  W3  to  xj,  and  including  these  signals  in 
-.  penalized  activity  in  their  corresponding  states.  The  effect  was  similar  to  that  of 
creating  rate  feedback  to  augment  damping,  common  to  a  classical  controls  approach. 
Importantly,  W3  did  not  need  to  have  full  rank.  This  permitted  us  to  set  multiple 
weights  to  zero  and  use  non-zero  values  only  in  the  event  that  a  particular  signal  was 
necessary  to  improve  damping.  As  a  result  VFa  had  the  following  form: 


VFa  =  diag(c,),  ?  =  7,...,11, 


where  c,’s  were  used  to  improve  damping  in  a  particular  mode,  as  will  be  discussed 
in  the  next  section. 

The  vector  y  included  the  system’s  sensor  outputs.  Furthermore,  y  had 
to  include  the  integral  error  state  in  order  to  satisfy  the  (C2,A,B2)  detectability 
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assumption  of  Theorem  3.1.  Consequently,  y  was  comprised  of; 

hf  a  DLC  ] 

y  =  h  a  Vt  0  iig  q  —  -  - 

s*  s  a 

One  artificiality  was  introduced  at  this  point;  the  presence  of  the  integrated  error 
terms  in  y  necessitated  the  inclusion  of  noise  signals  on  those  me^urements  within 
the  synthesis  model  in  order  to  satisfy  the  rank  condition  on  Z)}.  Since  the  bandwidth 
of  these  “observations”  were  arbitrary,  we  set  them  to  the  highest  frequency  of  the 
other  observations. 

In  summary,  the  cost  function  penalized  a  vector  of  the  weighted  integrated 
errors,  the  rates  on  principal  plant  dynamic  states  and  the  control  inputs.  The  design 
process  to  be  discussed  is  essentially  a  procedure  for  adjusting  the  weights  on  H^i,  Wj 
and  W3  in  order  to  achieve  the  design  specifications. 

2.  The  Design  Procedure 

The  design  process  is  summarized  next,  followed  by  a  detailed  discussion 
of  how  each  of  the  design  steps  were  applied  to  the  design  example; 

1,  .Set  all  W3  weights  to  zero.  Use  state-feedback  design  to  determine  weights  for 
Wi  and  W2  to  satisfy  the  command  and  control-loop  bandwidth  requirements. 


2.  If  damping  was  unsatisfactory,  refine  the  state-feedback  design  by  adjusting 
1^3  weights  to  include  lightly  damped  states  in  output  z.  These  states  were 
identified  by  examining  the  eigenvectors  associated  with  lightly  damped  eigen¬ 
values  of  i4  -f  where  A',/6  was  the  state-feedback  gain  determined  in 

step  1  above.  The  maximum  element  of  that  eigenvector  corresponded  to  the 
state  contributing  most  to  the  lightly  damped  mode.  Increasing  the  weight  in 
the  corresponding  W3  entry  had  the  effect  of  damping  the  dynamic  activity  of 
that  state.  Readjust  W\  and  W2  weights  to  maintain  the  previously  achieved 
bandwidth  specifications. 
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3.  Given  VKi,2,3  weights  determined  above,  use  measurement  feedback  design  to 
determine  the  sensor  noise  weights  in  14^4  necessary  to  satisfy  sensor  response 
bandwidths. 

4.  Determine  the  process  noise  weiglits  in  W4  by  analysis  of  the  broken-loop  con¬ 
troller  responses,  adjusting  the  weights  as  necessary  to  match  the  cross-over 
frequencies  that  were  observed  for  the  state-feedback  design.  This  step  is  simi¬ 
lar  to  Loop  Transfer  Recovery  (LTR)  technique  developed  for  linear  quadratic 
methods. 

.5.  Readjust  kk'i.a.a  as  required  to  maintain  previously  achieved  specifications. 

6.  Evaluate  resultant  controller  using  linear  and  nonlinear  simulation.  Adjust 
weights  as  necessary. 

7.  Confirm  satisfaction  of  other  specification  elements:  robustness,  damping,  and 
no  cancellation  of  lightly  damped  open-loop  poles. 

a.  State-Feedback  Design  -  Determining  the  and  14^2  Weights 
The  objective  of  this  step  was  the  determination  of  the  appropriate  Wi 
and  14''2  weights  to  achieve  the  specified  command  and  controller  bandwidths.  Visual 
inspection  of  bode  plots  for  the  broken-loop  controller  responses  and  the  closed-loop 
command  responses  indicated  which  weight  to  adjust  for  the  next  design  iteration. 
As  a  general  rule,  increasing  the  weight  on  the  integral  errors  (Wi)  increased  the 
bandwidth  of  the  respective  command  response  channel,  and  increasing  the  weight 
on  the  controller  commands  (W2)  decreased  the  broken-loop  cross-over  frequency. 
This  is  identical  to  the  behavior  noted  in  W2  design,  and  is  consistent  with  intuition, 
i.e.,  increasing  the  relative  cost  of  the  integral  error  should  increase  the  closed-loop 
responsiveness  of  that  channel  in  order  to  rebalance  the  costs.  Similarly,  increasing 
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tlie  relative  cost  on  a  specified  control  signal  should  decrease  the  amount  of  energy 
applied  to  that  control  channel,  and  result  in  a  decrease  of  that  controller’s  bandwidth. 
While  adjustment  of  the  weight  on  a  given  term  consistently  had  the  desired  effect  on 
the  corresponding  bandwidth,  internal  coupling  meant  that  the  influence  of  a  given 
weight  was  not  unidirectional  and  occasionally  resulted  in  wild  variations  in  the  other 
Bode  traces,  invariably  in  the  most  undesirable  direction.  Occasionally,  significant 
variations  could  also  be  attributed  to  the  binary  search  stopping  on  a  value  much 
closer  to  the  optimal  than  the  tolerance.  Considerable  time  could  be  expended  chasing 
the  various  Bode  traces,  if  an  orderly  methodology  was  not  followed.  Generally,  once 
a  desired  cross-over  or  corner  frequency  was  attained,  weights  were  then  adjusted  in 
response  to  adverse  coupling  effects  to  restore  that  value  to  spec  before  any  further 
adjustment  of  other  bandwidths.  Table  4.1  depicts  both  the  nominal  performance 
and  the  refined  performance  for  several  iterations  as  the  weights  were  varied.  Each 
entry  represents  the  weight  applied  to  the  identified  term  in  z  in  the  numerator,  and 
the  resulting  bandwidth  in  that  channel  in  the  denominator.  The  column  for  damping 
ratio  represents  the  minimum  damping  ratio  for  all  complex  closed-loop  poles.  The 
frustration  attendant  with  coupling  across  terms  is  evident  from  iteration  two  to 
three.  Raising  the  second  weight  from  the  first  to  second  iteration  had  successfully 
pushed  the  q  response  up  to  above  one,  but  had  an  undesirable  influence  on  the  DLC 
response. 

b.  Improving  the  State-Feedback  Design:  Rate  Feedback  for 

Damping 

By  the  third  iteration,  the  bandwidths  had  been  balanced  close  enough 
to  the  desired  specifications  to  attempt  improvement  of  closed-loop  damping.  The  ob¬ 
jective  here  was  to  identify  the  principal  .states  participating  in  under-damped  modes, 
and  increase  the  weight  on  their  respective  rates  in  the  output  z  such  that  activity 
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TABLE  4.1:  STATE-FEEDBACK  DESIGN:  WEIGHTS/RESULTING 
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ill  that  mode  was  penalized.  The  intent  was  identical  in  philosophy  to  the  purpose  of 
rate  feedback  in  classical  control  design.  At  the  third  iteration,  the  closed-loop  sys¬ 
tem  matrix  [A  BjKgfb)  had  two  complex  pairs  of  eigenvalues  with  damping  ratios 
of  0.55  and  0.43.  The  two  eigenvectors  corresponding  to  these  under-damped  modes 
pointed  in  the  directions  of  the  h/s  and  q  states  respectively.  This  indicated  that 
ll/s  and  q  were  the  dominant  participants  in  each  of  the  two  under-damped  modes. 
Since  h/s  was  a  state  internal  to  the  controller  it  was  disregarded,  and  attention  was 
focused  on  enhancing  the  damping  on  q.  To  improve  the  damping  of  these  modes, 
the  weighted  output  q  was  included  in  z  and  the  value  of  the  corresponding  term  in 
W2  was  increased  to  a  non-zero  value. 

Initially  a  very  small  weight  was  introduced  relative  to  the  other 
weights.  Each  time  a  damping  weight  was  adjusted,  the  Wi  and  14^2  weights  were 
readjusted  in  response,  to  regain  the  bandwidth  characteristics  previously  achieved, 
jjrior  to  further  refinement  of  the  damping  weights.  The  eigen  analysis  was  performed 
prior  to  each  adjustment  of  the  damping  weights  to  identify  the  most  active  state  of 
each  under-damped  mode,  and  to  insure  that  a  different  mode  with  different  modal 
participation  had  not  become  under-damped.  In  fact,  by  penalizing  participation  of 
q  in  the  under-damped  mode,  the  mode  shifted  into  the  a  and  0  states,  requiring  the 
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Fmiutney  (taiM) 

Figure  4.3:  Broken  Loop  Controller  Responses 

inclusion  of  a  penalty  against  the  respective  rate  terms.  Rarely  was  more  than  one 
weight  adjusted  per  design  iteration,  to  preclude  obscuring  the  influence  of  each  ad¬ 
justment.  A  total  of  24  iterations  were  required  to  achieve  the  design  that  approached 
both  bandwidth  and  damping  specifications.  From  Table  4.1,  the  weighting  functions 
VFi,  W2  and  W3  at  the  conclusion  of  this  phase  had  the  following  values: 

/^00\  /5  0  0\ 

Wi=  0  f  0  ,  1^2=  0  0.01  0  ,  VFa  =  diag(0, 10,5, 1,0). 

\  0  0  f  /  Vo  0  1  / 

Figures  4.3  and  4.4  depict  the  broken-loop  controller  responses,  and  the  closed-loop 
command  responses  for  this  selection  of  weights. 

c.  Output  Feedback  Controller  Design  -  Selecting  the  Measure¬ 
ment  Noise  Weights 

The  next  step  was  to  determine  the  weights  to  be  applied  to  the 
measurement  noise  signals,  which  mathematically  show  up  only  in  the  D2  matrix 
of  the  synthesis  model.  Initially,  the  weights  on  the  regulated  output  z  determined 
by  the  state-feedback  design  process  were  used  in  the  output  feedback  design.  The 


58 


Fr*qu«ncy  (taM) 


Figure  4.4:  Closed-Loop  Command  Responses 

objective  of  this  phase  was  to  tune  the  controller  such  that  the  influence  of  each  sensor 
channel  on  the  controller  did  not  exceed  the  expected  reliability  of  the  sensor.  For 
example,  if  a  sensor  could  be  regarded  as  reliable  at  frequencies  up  to  10  rad/s,  then 
the  controller  response  to  that  sensor  channel  should  roll  off  at  a  frequency  less  than 
or  equal  to  10  radfs.  Consider  the  following  representation  of  the  controller: 


=  1  <  = 

\  «  =  CeC 


+  Bey 


The  frequency  responses  of  the  diagonal  terms  of  the  transfer  function  matrix 
C^isl  —  Ac)~^Bc  were  plotted  to  evaluate  the  influence  of  each  channel  on  the  con¬ 
troller  (Figure  4.5).  The  outputs  of  this  transfer  matrix  represent  the  estimates  of  the 
states  of  Q  in  the  presence  of  the  worst  case  disturbance  [Ref.  18].  By  examination 
of  the  corner  frequency  for  each  of  the  ten  channels  of  C2{sl  —  Ac)~^Bc,  the  weights 
could  be  adjusted  to  achieve  the  desired  sensor  response  bandwidth.  Increasing  the 
weight  on  a  given  term  resulted  in  the  bandwidth  for  that  channel  being  decreased. 
This  is  similar  to  the  results  encountered  in  'Hj  design  and  is  consistent  with  intu- 
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FN^utnoir  (laM) 

Figure  4.5:  Sensor  Responses 


ition.  Very  little  effort  was  required  to  find  the  appropriate  set  of  weights  since  little 
coupling  was  observed  between  the  sensor  channels.  The  accelerometer  bandwidths 
could  not  be  exceed  10  radfsec  because  of  the  internal  dynamics  of  the  controller. 

d.  Output  Feedback  Controller  Design  •  Selecting  the  Process 
Noise  Weights 

The  next  step  of  the  design  process  was  the  determination  of  the 
process  noise  weights.  This  pha.se  was  similar  in  execution  to  the  “loop  recovery” 
process  of  LTR,  with  a  slightly  different  purpose.  While  the  objective  with  LQG/LTR 
is  principally  the  recovery  of  state-feedback  robustness  properties,  the  objective  here 
wtis  the  recovery  of  the  performance  characteristics  of  the  state-feedback  controller, 
as  reflected  by  the  various  bandwidth  and  damping  specifications.  Unlike  each  of  the 
previous  steps,  in  which  a  specific  weight  could  be  expected  to  control  a  particular 
trace  on  the  graphs,  this  was  not  so  for  this  phase.  Additionally,  there  was  coupling 
into  the  closed-loop  sensor  responses  as  the  state  process  noise  weights  were  changed, 
which  required  some  additional  adjustment  of  the  sensor  noise  weights  to  maintain 
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the  desired  sensor  response  bandwidths.  The  final  value  of  was: 

1^4  =  0.00001  *  diag(0.1,  4,  4,  0.01,  .01,  .01,  0.1,  10,  10,  1,  5,  5,  5  ) 

e.  Linear  Simulation-  Assessing  the  Controller  Structure 

At  this  point  the  closed-loop  linear  system  was  simulated  in  order  to 
determine  whether  reasonable  actuator  deflections  were  being  used,  and  to  ensure 
that  an  altitude  ramp  could  be  tracked  while  controlling  a  to  a  desired  trim  value 
and  DLC  to  zero.  The  closed-loop  system  was  initialized  to  level  flight  and  then 
expected  to  intercept  and  track  an  altitude  ramp.  While  the  altitude  ramp  was  suc¬ 
cessfully  intercepted  and  tracked,  both  a  and  DLC  stabilized  at  values  other  than 
their  respective  set  points.  Examination  of  the  transfer  functions  from  altitude  com¬ 
mand  to  Q  and  DLC  revealed  only  a  single  zero  at  the  origin  within  each  numerator. 
In  both  cases  there  was  an  additional  zero  numerically  close  to  zero,  but  insufficient 
to  provide  the  desired  washout  characteristics.  To  achieve  these  characteristics,  an 
additional  integrator  was  added  to  both  channels  in  Wj.  A  new  controller  was  then 
obtained  using  this  modified  synthesis  model  with  the  same  scalar  weights  determined 
above.  This  controller  was  then  evaluated  using  the  identical  simulation,  with  the 
result  that  both  a  and  DLC  stabilized  at  their  desired  values.  Finally,  slight  change 
in  Wi  and  W2  resulted  in  the  final  determination  of  the  bandwidths.  The  final  values 
of  the  weighting  matrices  were: 
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Figures  4.6  and  4.7  depict  the  resulting  broken-loop  controller  responses  and  the 
closed-loop  command  responses.  The  Nyquist  plots  of  the  broken  loop  responses  for 
each  control  input  are  shown  in  Figure  4.8. 
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Figure  4.6:  Output  Feedback  Broken-Loop  Controller  Responses 


Figure  4.7:  Output  Feedback  Closed-Loop  Command  Responses 
3.  Specification  Compliance 

Figures  4.6  and  4.7  show  all  the  control  and  command  loop  bandwidths 
as  satisfying  their  respective  specifications,  with  the  exception  of  the  a  command 
response  which  is  slightly  low  at  approximately  0.8  radfsec.  The  notch  is  due  to  the 
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Figure  4.8:  Output  Feedback  Broken-Loop  Nyquist  Plot 


presence  of  a  zero  in  the  a  command  loop.  No  objectionable  properties  result  since 
that  channel  is  used  to  regulate  a  constant  command  rather  than  respond  to  changes  in 
the  command  signal.  The  Nyquist  plot  in  Figure  4.8  clearly  depicts  the  simultaneous 
phase  and  gain  margins  requirements  as  being  satisfied,  with  all  three  controller  traces 
staying  in  the  right  half  plane  for  all  frequencies.  Eigen  decomposition  of  the  closed- 
loop  system  revealed  a  complex  pair  of  eigenvalues  which  failed  the  damping  ratio 
requirement  (0.45).  Examination  of  the  corresponding  eigenvectors,  however,  revealed 
that  no  vehicle  states  and  only  controller  states  were  participating  in  this  mode. 

The  next  step  was  to  ensure  that  the  cancellation  of  the  plant’s  lightly 
damped  modes  by  the  controller  had  not  occurred.  The  controller  is  a  3  x  9  matrix 
of  transfer  functions,  and  while  cancellation  may  occur  in  one  or  several  channels, 
complete  cancellation  would  only  occur  if  all  the  channels  had  a  common  numerator 
term.  See  [Ref.  38]  for  a  discussion  of  multivariable  transmission  zeros.  Figure  4.9 
depicts  the  singular  values  of  the  open-loop  control  responses.  The  presence  of  a  clear 
spike  at  the  frequency  of  the  lightly  damped  phugoid  mode  and  a  small  bump  at  the 
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Figure  4.0:  Control  Loop  Gain  Singular  Values 

frequency  of  moderately  damped  short  period  mode  indicates  that  the  controller  has 
not  canceled  these  open-loop  poles.  Numerical  analysis  revealed  no  transmission  zeros 
in  the  controller,  further  confirming  the  absence  of  pole-zero  cancellations. 

4.  /I  Analysis 

The  robustness  analysis  was  performed  by  determining  the  structured  sin¬ 
gular  value  of  a  linearization  of  the  closed-loop  uncertainty  model  consisting  of  the 
nonlinear  plant  and  the  controller,  as  discussed  previously  in  section  B.4.  This 
linearization  was  performed  about  the  trimmed  operating  condition,  with  the  uncer¬ 
tainty  inputs  and  outputs  ws  and  zs  included  in  the  nonlinear  equations  of  motion 
as  shown  in  Figure  4.1.  Figure  4.10  depicts  the  resulting  structured  singular  value, 
where  the  peak  value  of  0.6  indicates  compliance  with  the  condition  of  Theorem  3.8 
and  the  robustness  design  specification. 

Note,  had  the  design  effort  failed  to  yield  the  desired  robustness,  the  design 
process  could  have  been  repeated  with  the  signals  ws  and  zg  incorporated  in  the 
synthesis  model,  and  using  either  Hoo  synthesis  or  D-K  iteration  [Ref,  35]. 
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Figure  4.10:  Structured  Singular  Value  Plot 
S.  Nonlinear  Simulation 

In  this  section  we  present  the  results  of  the  nonlinear  simulation  of  the 
H<x,  controller.  First,  the  controller  was  implemented  on  the  nonlinear  plant  using 
7?-implementation  methodology  (see  (Ref.  39)).  The  methodology  is  based  on  the 
observation  that  linear  controllers  are  designed  to  act  on  the  perturbations  about 
the  plant’s  nominal  trajectory.  Next,  as  with  the  linear  simulation  performed  in 
section  C.2.e,  the  controller  task  was  to  intercept  and  track  an  altitude  ramp,  while 
appropriately  controlling  the  other  signals  of  interest.  A  vertical  and  horizontal  gust 
field  of  moderate  intensity  (rms=  10/ps)  was  included  in  the  simulation.  Results 
are  depicted  in  Figure  4.11,  where  all  the  variables  are  shown  as  deviations  from  the 
trimmed  level  flight  condition.  The  simulation  was  initialized  in  steady  level  flight 
with  all  surfaces  at  their  trim  positions.  In  response  to  the  altitude  ramp,  the  DLC 
and  stabilizer  deflected  immediately  to  establish  the  appropriate  descent  rate.  The 
result  is  a  decrease  in  both  a  and  0.  The  altitude  overshoots  the  ramp,  and  then 
corrects  to  the  proper  trajectory.  Both  the  average  angle  of  attack  and  the  average 
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Figure  4.11:  Nonlinear  Simulation  Results 


DLC  wash-out  to  their  desired  trim  values  as  the  altitude  error  is  nulled  and  the  thrust 
decreases  to  stabilize  at  the  new  steady-state  condition.  Deflections  and  deviations 
are  all  well  within  reasonable  practical  values.  This  simulation  validated  the  results 
of  the  design  effort. 

6.  Hoo  Design  Conclusion 

A  measurement  feedback  controller  was  successfully  designed  to  provide 
longitudinal  control  of  an  F-14  aircraft  during  automatic  landing,  and  implemented 
on  a  nonlinear  simulation.  A  key  feature  in  the  design  was  the  exploitation  of  the 
aircraft’s  Direct  Lift  Control  to  provide  for  enhanced  landing  performance.  Addi¬ 
tionally,  a  methodology  was  detailed  whereby  SISO  performance  requirements  were 
achieved  using  Woo  synthesis.  Finally  the  resulting  controller  was  validated  on  the 
nonlinear  simulation. 
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D.  MIXED  Hi  /  Woo  CONTROLLER  DESIGN 

The  purpose  of  this  section  is  to  present  the  design  example  demonstrating  both 
an  application  of  the  W2  /  Woo  design  tools,  and  a  methodology  for  their  use.  The 
previous  problem  was  actually  born  out  of  a  desire  to  fully  develop  the  methodology 
for  the  pure  Woo  problem  prior  to  its  application  to  a  more  complicated  mixed 
problem.  Both  the  synthesis  and  analysis  models  used  the  identical  MATLAB  scripts 
and  SIMULINK  models  as  the  above  problem.  The  design  tools  for  this  problem  were 
created  by  the  author  and  are  developed  and  outlined  in  Appendix  A. 

1.  Problem  Description  and  Design  Requirements 

The  problem  description  and  design  requirements  for  this  example  were 
identical  to  those  outlined  in  section  B  above,  with  slight  modification.  In  order  to 
demonstrate  the  attributes  of  the  mixed  design  tools,  a  more  severe  robustness  re¬ 
quirement  was  included.  Specifically,  stability  was  to  be  guaranteed  for  simultaneous 
variations  of  40%  in  the  perturbed  lift  and  drag  forces  and  pitching  moment.  In  the 
previous  example,  the  robustness  of  the  closed-loop  system  was  assessed  after  the 
design  process.  In  this  design  example,  it  was  decided  to  explicitly  impose  the  ro- 
bustness  requirement  in  the  design  process  using  the  Woo  feature  of  the  design  tools. 
To  accommodate  the  increased  robustness  specification,  it  was  decided  to  relax  the 
desired  performance  requirement  slightly.  Rather  than  the  command  performance 
bandwidths  of  approximately  one  radjsec  which  had  previously  been  required,  the 
desired  command  bandwidths  were  set  at  approximately  0.5  rad/ sec. 

2.  Synthesis  Model 

The  Woo  design  tools  used  in  the  first  design  example  found  the  con¬ 
troller,  C  ,  that  minimized  ,C)||oo.  The  mixed  W2  /  Woo  tools  find  the  con¬ 
troller  that  minimizes  the  mixed  cost:  ,C  )|l2/oo»  subject  to  the  constraint 
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WT^g  X  )\\oo  <  r  Consequently,  the  synthesis  model  complexity  was  increased  in 
order  to  accommodate  the  signal  20,  which  was  not  present  in  the  previous  examp)' 
From  Chapter  III,  the  mixed  /  'Hoo  problem  required  that  the  synthesis  model 
be  posed  in  the  form: 

'  X  =  i4x  -f  Biw  +  B2U 

_  2o  =  CqX  +  Do\W  +  D02U  -V 

®  •=  =  C,x  +  £>,.«.  +  D„u 

,  y  =  C2X  +  Z)2iie  +  D22U 

In  order  to  pose  the  problem  in  this  form,  consider  Figure  4.12.  This  figure 
depicts  the  synthesis  model  where  the  signals  were  chosen  to  comprise  each  input 
and  output  vector.  The  choice  of  signals  to  include  in  w,  Zo  and  Zi,  as  well  as  the 
various  weighting  functions,  were  determined  both  by  mathematical  necessity,  and 
the  objectives  posed  by  the  problem  description. 


Figure  4.12:  Mixed  H2  /  'H^o  Synthesis  Model 

The  vector  z\  consisted  of  the  signals  whose  output  energy  would  be  limited 
by  the  Tioo  constraint.  Since  the  constraint  was  to  be  used  to  explicitly 
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achieve  the  specified  robustness,  the  uncertainty  input  w$  was  included  in  w,  and 
the  output  of  the  uncertainty  model  zs,  was  included  in  Zj.  The  uncertainty  model 
depicted  in  Figure  4.1  was  used  to  find  a  linearization  of  the  open-loop  system  with 
the  input  vector  tvs,  and  output  vector,  zg.  As  the  consequence  of  constraining 
l!T.,4c;,c)|U  <  7,  m».AQX)\\oo  <  7  would  be  guaranteed.  The  requirement 
have  full  column  rank  necessitated  the  inclusion  of  the  output  of  any 
pure  integrators,  and  the  requirement  that  Du  have  full  column  rank  necessitated 
the  inclusion  of  the  control  inputs  Uc  in  zi  as  well.  In  order  to  restrict  the  amount  of 
conservatism  that  these  two  signals  added  to  the  Hoc,  constraint  by  their  presence 
in  2],  small  attenuating  values  were  chosen  for  the  weighting  functions  and 
After  several  iterations  of  the  design  process  it  was  evident  that  double  integrators 
would  again  be  required  on  each  of  the  regulated  error  channels.  Consequently,  the 
final  weighting  matrices  on  z\  had  the  form: 

10“^ 

Ws,  =  -T-h  W,,  =  diag(10-^  10-®,  10-") 

s* 


that 


A 

Cl 


The  second  element  of  was  specifically  smaller  than  the  others  because  it  multi¬ 
plied  the  thrust  channel,  whose  units  (Ibf)  resulted  in  high  signal  amplitudes.  The 
weighting  function  was  set  to  0.4/  in  order  to  scale  the  uncertainty  model  such 
that  ,C  )|1oo  <  ,C  )||oo  <7=1  would  satisfy  the  robustness  spec¬ 

ification  of  40%  gross  parametric  variation.  Each  of  these  weighting  functions  were 
constants  and  not  adjusted  during  the  design  procedure. 

The  vector  Zq  represented  those  signals  which  would  appear  in  the  quadratic 
cost  function.  As  with  the  previous  pure  Hoo  problem,  the  weighting  functions 
W\,  W2,  IFa,  and  consequently  represented  the  degrees  of  design  freedom,  while 
constrained  by  the  above  Hoo  specification.  In  order  to  achieve  similar  results  as 
the  previous  example,  zq  was  selected  to  be  identical  to  the  previous  2,  as  was  the 
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structure  of  the  weighting  matrices.  To  be  able  to  adjust  the  command  bandwidths, 
the  integrated  errors  were  again  included  in  the  output  signal,  resulting  in  the  first 
weighting  matrix  having  form: 

0  0  \ 

VV',  =  0  ^  0  . 

v  0  0  ^ ; 

As  in  the  previous  problem,  W2,  and  were  diagonal  matrices  of  constants. 

3.  The  Design  Procedure 

The  design  process  was  virtually  identical  to  that  outlined  in  section  2. 
above.  The  only  exceptions  were  in  the  formulation  of  the  synthesis  model,  as  de¬ 
scribed  above,  and  in  the  use  of  the  mixed  /  'Hoo  design  functions  outlined  in 
Appendix  A,  in  lieu  of  the  commercial  Hoo  design  tools.  Due  to  lack  of  time,  the 
design  example  was  terminated  with  the  design  of  a  state-feedback  controller,  how¬ 
ever,  Appendix  A  does  include  both  the  state-feedback  and  measurement  feedback 
design  routines. 

Since  the  procedure  otherwise  followed  the  procedure  of  the  first  example 
exactly,  the  details  are  omitted.  The  mixed  H2  /  Hoo  design  tools  did  permit  the 
selection  of  which  generalized  mixed  costs  was  to  be  used  (trace,  maximum  eigenvalue 
or  maximum  diagonal  element).  Several  iterations  were  done  using  both  the  trace  and 
the  maximum  eigenvalue.  It  was  observed  that  the  trace  was  more  appropriate  to  this 
particular  methodology,  in  that  it  was  easier  to  influence  all  of  the  various  bandwidths 
by  adjustments  of  the  weighting  matrices.  Several  bandwidths  were  comparatively 
insensitive  to  adjustments  of  the  weights  when  using  the  maximum  eigenvalue  as  the 
cost  functional.  This  is  consistent  with  intuition  when  one  considers  the  geometric 
implications  of  choosing  the  trace  relative  to  the  maximum  eigenvalue.  Table  4.2 
summarizes  the  progress  of  the  design  effort  using  the  trace.  Each  design  iteration 
required  approximately  30  minutes  of  cpu  time  on  a  SparclO  workstation.  Step  9 
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TABLE  4.2:  STATE-FEEDBACK  DESIGN:  WEIGHTS/RESULTING 
BANDWIDTHS _ ^ ^ 
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marked  the  point  when  the  additional  integrators  were  added  to  the  weighting  matrix 
W\.  This  altered  several  bandwidths  slightly,  though  the  scalar  weights  themselves 
were  not  adjusted  between  steps  eight  and  nine. 

The  above  design  resulted  in  two  pairs  of  lightly  damped  eigenvalues,  with 
damping  ratios  between  0.2  and  0.4.  Modal  analysis  revealed  that  only  the  thrust 
was  significantly  participating  in  these  modes,  with  no  participation  by  the  aerody¬ 
namic  states.  This  was  regarded  as  acceptable,  and  no  further  damping  improvement 
was  attempted.  The  weighting  matrix  Vis  was  consequently  all  zeros.  Since  the 
measurement-feedback  controller  was  not  pursued,  the  weighting  matrix  was  left 
as  all  zeros  as  well. 

4.  Specification  Compliance 

Figures  4.13  and  4.14  depict  the  broken-loop  controller  responses,  and  the 
closed-loop  command  responses.  Each  of  the  broken-loop  controller  responses  is  less 
than  the  specification,  indicating  that  the  actuators  would  not  be  driven  at  frequen¬ 
cies  greater  than  their  bandwidths.  The  closed-loop  command  responses  of  0.4  for 
the  altitude  and  DLC  channels  were  slightly  less  than  the  specification  value  of  0.5 
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Figure  4.13:  Broken-Loop  Controller  Responses 

rad! sec.  Figure  4.15  depicts  the  Nyquist  plot  for  the  broken-loop  controller  responses. 
The  Nyquist  plot  shows  the  controller  loops  as  satisfying  the  simultaneous  phase  and 
gain  margins,  with  the  exception  of  the  DLC  loop  which  slightly  violated  the  out¬ 
side  corners.  It  is  interesting  that  the  DLC  loop  stays  outside  the  unit  circle  around 
(-1,0),  as  would  be  expected  when  using  Loop  Transfer  Recovery  Methods  with  a 
pure  controller  design  tool. 

Figure  4.16  depicts  the  singular  values  of  the  open-loop  controller  response. 
The  clear  peak  corresponding  to  the  short-period  frequency  indicates  that  this  mode 
was  not  canceled  by  the  controller. 

5.  /i-Analysis 

Figure  4.17  depicts  the  structured  singular  values  for  the  closed-loop  system 
,C  ).  The  peak  value  less  than  one  confirms  the  robust  stability  of  the 
system  to  uncertainties  greater  than  the  specified  40%.  That  the  peak  value  is  well  less 
than  one  highlights  the  conservative  nature  of  using  constraints  for  robustness 
when  the  uncertainty  can  be  expressed  in  a  structured  fashion. 
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Figure  4.14:  Closed-Loop  Command  Responses 


Figure  4.15:  Broken-Loop  Nyquist  Response 
6.  Linear  Simulation 

A  linear  simulation  was  performed  in  order  to  ensure  that  the  resulting 
closed-loop  system  fulfilled  the  design  requirements.  Figure  4.18  depicts  the  response 
of  the  system  to  a  ramp  altitude  command.  All  variables  are  depicted  as  perturbations 
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Figure  4.16:  Open-Loop  Singular  Values 


Fwqmnoy 


Figure  4.17:  Closed-Loop  Structured  Singular  Values 
from  their  trimmed  condition. 

Since  the  command  bandwidths  are  slower  than  those  for  the  first  design 
example,  the  response  of  the  regulated  signals  to  the  altitude  ramp  is  predictably 
slower.  The  desired  wash-out  characteristics  are  displayed,  though,  on  altitude  error. 
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Figure  4.18:  Linear 


Simulation  Results 


angle-of-attack,  and  DLC  deflection. 

7.  Mixed  Hi  /  Controller  Design  Conclusions 

The  methodology  of  section  C.  was  successfully  extended  for  use  in  the 
design  of  mixed  Hi  /  Koo  state-feedback  controllers.  Furthermore,  a  synthesis  model 
formulation  was  demonstrated  whereby  the  Hi  /  Hoo  design  tools  could  be  applied  in 
order  to  achieve  explicit  robustness  guarantees,  simultaneous  with  other  classical  SISO 
design  requirements.  The  final  controller  design  was  validated  by  linear  simulation. 


E.  CONTRASTING  THE  H^  AND  Hi  /  Hoo  DESIGN  TOOLS 

Because  of  the  similar  synthesis  models  and  design  methodologies,  the  effort 
required  to  implement  the  two  tools  was  virtually  identical.  In  fact,  a  single  MAT- 
LAB  m-file  was  used  to  prepare  the  two  synthesis  models,  with  only  slight  variations 


75 


required.  A  positive  attribute  of  the  tools  was  that  little  procedural  ef¬ 
fort  was  required  to  shift  to  the  H2  /  ^oc  tools  from  the  tools.  The  mixed 

^2  /  design  tools  did  demonstrate  one  significant  disadvantage  over  the  pure 
method.  While  the  computation  of  a  single  Hoc,  controller  would  require  less 
than  .fO  seconds,  the  computation  of  an  H^  /  Hoc.  controller  for  this  14  state  problem 
required  between  12  and  45  minutes,  depending  on  the  scalar  weights  chosen.  This 
was  partially  attributable  to  the  particular  implementation  of  the  convex  optimization 
methods.  The  computational  time  could  be  probably  be  dramatically  reduced  with 
a  FORTRAN  or  C  implementation  of  the  interior  point  method,  rather  than  the  el- 
lisoidal  codes  used  here.  However,  even  th''  most  efficient  optimization  routine  will  be 
dramatically  slower  than  the  nearly  direct  computational  means  available  by  Riccati 
methods,  (mnsequently,  the  mixed  H2  /  Hoc  tools  should  only  be  used  in  situations 
where  the  H2  norm  is  an  explicit  expression  of  some  specific  design  specification.j 

F.  CONCLUSION 

This  chapter  demonstrated  the  application  of  Hoc  and  mixed  Hj  /  Hoc  con¬ 
troller  design  tools  to  the  problem  of  autoland  controller  design.  A  methodology 
was  presented  whereby  cla.ssiral  SISO  design  specifications  could  be  translated  into 
scalar  weighting  functions  appended  to  the  synthesis  model  for  either  controller  design 
scheme.  Furthermore,  a  methodology  was  presented  for  the  modeling  of  uncertainties 
in  flight  dynamics  problems,  and  was  then  applied  in  the  analysis  of  the  robustness 
of  the  resulting  closed-loop  systems. 
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V.  INTEGRATED  AIRCRAFT/CONTROLLER 
DESIGN  BY  LINEAR  MATRIX 
INEQUALITIES 

This  chapter  presents  a  methodology  by  which  aerodynamic  surface  sizes  can  be 
optimized  using  performance  requirements  which  are  posed  as  Linear  Matrix  Inequal¬ 
ities.  Several  examples  are  presented  which  demonstrate  the  utility  and  flexibility  of 
the  method.  The  MATLAB  files  which  support  the  material  of  this  chapter  can  be 
found  in  Appendix  D. 

A.  INTRODUCTION  AND  PROBLEM  MOTIVATION 

The  control  design  process  for  rigid  body  vehicles  (air,  marine  and  space)  in¬ 
cludes  not  only  the  design  of  the  control  system  itself,  but  also  the  refinement  of  the 
size  of  the  control  effectors.  Generally,  the  shape  and  overall  size  of  the  vehicle  is 
dictated  by  mission  constraints  such  as  payload,  range,  or  maximum  speed.  Control 
effectors  and  stabilizing  surfaces  are  then  appended  to  the  baseline  vehicle  to  pro¬ 
vide  sufficient  control  power  so  that,  in  concert  with  an  appropriate  control  design, 
the  desired  dynamic  performance  is  realized.  Control  power  is  very  expensive, 
resulting  in  increased  weight,  drag,  signature,  and  financial  cost.  Consequently,  the 
configuration  designer  would  like  to  incorporate  only  that  amount  of  control  power 
that  is  necessary  to  attain  the  desired  dynamic  performance  requirements.  The  ad¬ 
vance  of  controls  technology  in  the  past  25  years  have  led  many  commercial  and 
military  aircraft  designers  to  consider  reduced  static  stability  aircraft  as  a  means  of 
improving  performance  and  lowering  cost. 
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The  question  spawned  by  this  drive  toward  improved  performance  is  consequently — 
how  much  control  is  enough?  There  are  actually  two  facets  to  the  question.  First 
of  all,  flying  qualities  specifications  must  be  identified,  which,  if  satisfied  will  permit 
the  vehicle  to  meet  its  mission  requirements.  Much  of  this  field  relies  on  the  subjec¬ 
tive  opinions  of  pools  of  research  pilots  and  engineers.  Flying  qualities  consequently 
translates  mission  requirements  into  dynamic  performance  requirements.  Consider¬ 
able  work  heis  been  invested  by  the  military  services  and  NASA  in  recent  years  to 
expand  the  traditional  flying  qualities  standards  [Ref.  1]  to  the  new  paradigm  of 
relaxed  static  stability  aircraft.  The  second  facet  of  the  problem  is  translating  the 
flying  qualities  specifications  into  physical  configurations  and  control  systems.  This 
question  is  addressed  by  this  work. 

In  aeronautical  applications,  control  sizing  is  driven  by  several  distinct  environ¬ 
ments.  Each  of  these  must  be  independently  considered  in  the  design,  and  the  most 
stringent  adopted.  The  three  principal  environments  are: 

•  Take-off,  Approach  and  Landing  (terminal  area  flight); 

•  High  angle  of  attack  flight; 

•  Supersonic  flight. 

Corresponding  to  each  of  these  environments  is  a  set  of  critical  center-of-gravity  {eg) 
locations.  For  each  of  these  eg  locations,  sufBcient  control  power  must  exist  to  provide 
the  controls  designer  with  the  capacity  to  achieve  appropriate  dynamic  performance 
(stability,  maneuverability,  and  disturbance  rejection)  for  both  nominal  and  failure 
conditions.  However,  the  nature  of  the  control  power  required  to  provide  such  per¬ 
formance  differs  greatly  from  environment  to  environment.  For  example,  in  the  case 
of  supersonic  flight,  the  principal  issue  is  maneuverability.  Here,  control  power  can 
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be  degraded  by  changes  in  the  aircraft  center  of  pressure  or  blanking  of  the  control 
surfaces  by  shock-waves.  Experience  with  supersonic  flight  has  provided  a  base  of 
knowledge  for  providing  adequate  control  power  in  this  environment.  Since  control 
power  is  basically  proportional  to  the  airspeed  squared,  it  is  more  frequently  crit¬ 
ical  at  the  other  extreme  of  the  operating  envelope,  at  slow  speed,  such  as  during 
high-angle-of-attack  maneuvering  and  take-off/approach/landing.  In  the  case  of  high 
angle-of-attack  flight,  the  aerodynamics  are  very  non-linear,  and  the  concern  is  the 
ability  to  generate  specific  rates  or  accelerations  (maneuverability).  The  specifications 
are  therefore  generally  expressed  as  open-loop  rates  or  accelerations. 

The  specifications  determining  the  control  power  requirements  for  slow  speed 
terminal-area  flight  are  both  closed-loop  and  open-loop.  In  this  environment,  the 
concern  of  the  configuration  designer  is  to  provide  the  controls  designer  with  adequate 
control  power  such  that  a  controller  can  be  designed  which  satisfies  the  specified 
closed-loop  flying  qualities,  as  well  as  open-loop  maneuverability.  Unlike  the  other 
two  environments,  linear  flight  mechanics  prevail,  and  the  vehicle  can  reasonably  be 
modeled  as  a  linear  system.  A  significant  portion  of  the  control  sizing  problem  is 
consequently  a  linear  controls  problem. 

This  chapter  addresses  the  problem  of  simultaneous  aircraft/controller  opti¬ 
mization.  As  discussed  in  Chapter  III,  many  closed-loop  control  problems  and  flying 
qualities  specifications  can  be  formulated  as  convex  optimization  problems,  some  of 
which  can  further  be  simplified  into  LMI’s.  It  has  been  our  observation  that  for  many 
rigid  body  systems,  performance  specifications  which  are  posed  as  LMI’s  provide  a 
means  for  not  only  solving  the  controller  design  problem,  but  also  directly  determin¬ 
ing  the  upper-bound  for  the  minimum  necessary  control  power.  As  a  result  of  the 
this  work,  the  aircraft  and  control  system  designers  will  be  provided  with  a  new  tool 
capable  of  answering  the  plant/controller  optimization  problem: 
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Given  the  flying  qualities  requirements  for  a  specified  mission,  find  the 
minimum  aerodynamic  surface  sizes,  and  a  feedback  controller,  which  to¬ 
gether  satisfy  mission  requirements. 

The  answers  obtained  are  important  to  reduce  aircraft  weight,  size,  and  ob¬ 
servability  and  would  result  in  cost  savings  in  many  current  and  future  aircraft  pro¬ 
curement  programs.  The  application  of  these  methods  is  certainly  not  restricted  to 
aeronautical  applications,  in  that  control  power  is  expensive  in  all  engineering  sys¬ 
tems.  In  a  chemical  process  system,  the  control  power  is  reflected  in  the  diameters  of 
the  pipes  and  tubing.  The  controls  designer  here  is  no  less  interested  in  minimizing 
the  costs  of  achieving  adequate  control  power. 

For  aeronautical  applications,  the  seminal  work  to  date  on  this  subject  was  a 
design  gu'de  published  by  the  Grumman  Corporation  in  support  of  NASA’s  X-29 
program  (F:ef.  5].  The  scope  of  that  effort  was  significant,  including  non-linear  aero¬ 
dynamics  and  flexible  structures,  issues  which  were  beyond  the  scope  of  the  material 
treated  by  this  research.  The  authors  acknowledged,  however,  that  a  limitation  to 
their  approach  was  the  a  priori  choice  of  the  structure  of  the  controller.  They  sug¬ 
gested  that  optimization  tools  would  be  required  in  order  to  relax  this  constraint.  The 
problem  considered  in  (Ref.  5]  is  consequently  a  search  over  the  set  of  plant  config¬ 
urations  that,  in  concert  with  the  specified  controller,  yield  the  desired  performance 
requirements.  Recently  developed  computational  tools  (such  as  those  presented  in 
Chapter  II)  and  the  convex  formulation  of  many  powerful  control  problems  now  per¬ 
mit  the  consideration  of  the  larger  problem,  where  the  designer  is  not  restricted  to  a 
specified  controller  structure,  but  can  instead  examine  the  set  of  all  controllers  which 
satisfy  the  performance  measures. 
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The  sections  that  follow  present  a  formulation  and  methodology  for  the  opti¬ 
mization  of  an  airframe  using  LMI’s  to  pose  the  design  constraints.  First,  section 
B  will  define  the  problem.  Then,  in  section  C,  a  pure  'Hoc  constraint  will  be  used 
to  pose  disturbance  rejection  requirments.  A  formulation  will  then  be  presented  for 
the  solution  of  the  plant/controller  optimization  problem,  and  demonstrated  by  an 
example.  The  example  problem  will  be  a  regulation  problem  in  which  there  is  no 
command  tracking  signal,  but  instead  a  controller  which  simply  stabilizes  the  system 
and  provides  a  specified  disturbance  attenuation.  This  section  will  also  present  how 
this  formulation  can  be  expanded  to  inchide  diverse  Hoo  specifications  at  multiple 
flight  conditions.  Next,  in  section  D,  both  internal  stability  and  disturbance  rejection 
specifications  will  be  considered.  Section  E  will  present  several  methodologies  for 
formulating  the  various  open-loop  maneuverability  requirements  as  LMTs.  The  ex¬ 
amples  in  this  section  will  demonstrate  the  application  of  open-loop  maneuverability 
requirements.  Next,  section  F  presents  a  formulation  for  accommodating  paramet¬ 
ric  uncertainty  in  plant  optimization  process.  In  wrapping  up,  section  G  discusses 
the  results,  their  limitations,  and  other  applications,  while  section  H  discusses  future 
directions  for  this  research. 

B.  PROBLEM  DESCRIPTION 

Once  again,  the  problem  we  sought  to  address  in  this  research  can  be  stated  as 
follows: 

Given  the  flying  qualities  requirements  for  a  specified  mission,  find  the 
minimum  aerodynamic  surface  sizes,  and  a  feedback  controller,  which  to¬ 
gether  satisfy  mission  requirements. 

It  will  be  shown  that  determining  an  upper-bound  to  the  optimum  answer  to  this 
problem  can  be  reduced  to  minimizing  a  linear  cost  (a  function  of  aircraft  parameters) 
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subject  to  matrix  inequalities  which  represent  the  mission  performance  requirements. 
The  problem  formulation  and  proposed  solutions  are  discussed  next. 

Let  C  be  a  vector  of  the  aircraft  parameters  which  we  would  like  to  optimize. 
Furthermore,  suppose  the  plant  matrices  A,  Bx  and  B2  can  be  expressed  as  affine 
functions  of  the  plant  parameters.  In  other  words,  let 

»=i 

B,  =  B(C)  =  flio  +  EC.BK, 

tsl 

Bi  =  B(Q  =  B20  + 

1=1 

Later  examples  will  demonstrate  that  many  plant  parameters,  such  as  the  area  of  an 
aerodynamic  control  surface,  naturally  occur  as  affine  variables  in  a  dynamic  systems. 
Since  (  represents  physical  sizes  for  the  proposed  problem,  we  constrain  Ci  >  0.  Let 
J  =  be  the  cost  function,  where  c,  >  0  denotes  the  relative  cost  we  choose  to 
assign  to  each  parameter  For  example  if  we  seek  to  minimize  the  total  mass  of  the 
physical  control  surfaces,  and  were  the  physical  area  of  each  control  surface,  then 
c,'  might  be  the  ma.ss  per  unit  area,  and  J  the  total  weight  of  the  subject  components. 
Or  c,  could  be  selected  to  be  the  cost  per  unit  area,  in  which  case  J  is  the  total  cost  of 
adding  surfaces  under  consideration.  The  linear  cost  functional  J(Q  is  clearly  convex 
ill  (.  While  a  linear  combination  of  the  optimization  parameters  is  the  easiest  to 
accommodate,  the  general  formulation  proposed  would  permit  any  convex  function 
of  the  optimization  parameters.  The  general  problem  can  now  be  stated  as: 

Minimize:  J  = 

Subject  to:  F(C,0  <  (5.1) 

where  F(C,0  <  0  reflects  all  the  relevant  performance  requirements.  It  was  our  desire 
to  determine  if  these  performance  constraints  could  be  posed  in  some  manner  that 
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would  permit  solution  of  the  optimization  problem  by  convex  methods.  In  order  to 
do  this,  we  considered  the  various  types  of  constraints  which  typically  arise  in  flight 
mechanics. 

The  three  general  sets  of  performance  criteria  which  drive  control  power  re¬ 
quirements  are  stabilization,  disturbance  rejection,  and  maneuverability  [Ref.  5]. 
Stabilization  requirements  pertain  to  the  internal  dynamics  of  the  problem  and  are 
frequently  posed  as  pole-placement  requirements.  Much  of  the  concern  relevant  to 
control  power  optimization  can  be  attributed  to  the  trend  towards  vehicles  with  un¬ 
stable  open-loop  modes,  and  the  acknowledgment  that  some  portion  of  the  control 
power  would  have  to  be  devoted  to  providing  closed-loop  stability.  Simple  stabil¬ 
ity  can  be  posed  as  either  a  Lyapunov  inequality,  or  an  Hoo  constraint.  Chapter 
III  described  how  a  pole-placement  requirement  could  be  posed  as  convex  matrix 
inequalities. 

The  second  type  of  requirement  which  influences  the  necessary  control  power 
is  disturbance  rejection  requirements.  These  are  usually  posed  as  limitations  on  the 
I'ins  output,  as  a  consequence  of  a  specified  rms  input.  The  disturbance  attenua¬ 
tion  specifications  can  be  directly  posed  as  H(x>  constraints,  which  we  know  to  be 
expressible  as  a  matrix  inequality.  The  inputs  are  generally  meteorological  gusts, 
represented  by  a  model  such  as  the  Dryden  turbulence  model  [Ref.  1].  The  outputs 
include  both  the  physical  response  of  the  states  and  the  closed-loop  response  of  the 
actuators.  The  specification  determines  the  first,  while  physical  constraints,  such  as 
the  actuator  deflection  limits  and  limit  rates,  define  the  limit  acceptable  values  for 
the  latter.  The  Hoo  constraint  is  well  suited  to  these  types  of  performance  measures 
due  to  its  power  gain  interpretation,  as  described  in  Chapter  III.  An  Hoo  constraint 
will  not  ensure  that  a  peak  actuator  deflection  can  not  exceed  a  given  value,  but  it 
can  limit  the  power  signal  of  the  actuators  deflection  and  rate. 
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Maneuverability  is  the  third  performance  measure  which  drives  control  power. 
The  constraints  here  have  the  form  that  a  specified  output  should  exceed  a  given 
value  when  all  relevant  controllers  are  fully  deflected  in  the  appropriate  direction. 
This  is  an  “open-loop”  requirement  to  a  flying  qualities  engineer  because  the  loop  in 
which  he  is  interested  is  open —  the  pilot’s  command  is  saturated  and  the  pilot  is  not 
trying  to  actively  track  some  variable.  This  need  not  imply  that  the  loops  within  the 
controller  are  “open”,  and  a  controls  engineer  may  use  either  an  open  or  closed-loop 
formulation. 

Maneuverability  requirements  can  actually  have  several  forms.  In  the  sizing  of 
a  rudder,  for  example,  it  may  be  a  requirement  that  the  minimum  moment  must 
exceed  that  required  to  balance  an  engine  out  condition.  In  this  case,  static  control 
power  is  the  issue.  As  will  be  shown  later,  this  can  directly  be  expressed  as  an 
LMI.  In  other  applications,  the  specification  may  require  that  the  system  exhibit 
a  minimum  body  rate  in  response  to  a  limit  command  input.  Since  most  of  our 
controllers  produce  either  moments  or  accelerations,  then  a  specified  steady  state 
rate  represents  the  output  of  a  dynamic  system.  These  types  of  specifications  can 
consequently  be  referred  to  as  dynamic  maneuverability  requirements  or  dynamic 
open-loop  requirements.  These  too  we  will  show  to  be  expressible  as  LMI’s. 

In  sum,  control  power  requirements  are  determined  by  the  joint  requirements  of 
closed-loop  internal  stability,  closed-loop  disturbance  rejection,  and  open-loop  maneu¬ 
verability.  Each  of  these  performance  constraints  can  be  posed  as  matrix  inequalities. 
The  joint  imposition  of  many  such  matrix  inequalities  provides  a  mechanism  for  solv¬ 
ing  the  subject  optimization  problem. 
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C.  APPLYING  DISTURBANCE  REJECTION  REQUIREMENTS 


In  this  section  we  will  formulate  the  plant/controller  optimization  problem, 
using  an  Hoo  specification  as  the  design  constraint  to  apply  disturbance  rejection 
requirements,  as  well  as  simple  closed-loop  stability.  Recall  equation  3.13,  which 
poses  the  'Hoo  performance  constraint  as  a  LMI: 


Rx{W,Y) 


AY-¥YA'-\-B2W-{-W'B'^  +  BxB[  (CY-\-DW)' 
(CY  -t-  DW)  -72/ 


(5.2) 


Assume  that  the  inputs  and  outputs  are  scaled  such  that  7=1,  and  consider  ^  to  be 
the  vector  of  the  controller  parameters  such  that  W  and  Y  are  affine  functions  of  (  and 
basis  matrices  VJ,  IV,:  Y  =  Y{()  =  >0  -I-  and  ^  =  IVo  +  YiUx 

^  ETI’  and  s  =  (n(n  -|- 1)/2)  -f  nq.  First,  using  Schur  complements,  equation  3.13  is 
equivalent  to  the  following  LMI: 


^2(C,0  := 


AY  +  YA'^  +  B2W  -I-  W^BJ  +  {CY  +  DWfiCY  +  DW) 

BJ 


Bx 

-1 


<0. 

(5.3) 


Note  that  this  constraint  is  affine  in  the  plant  matrices  A,  Bi  and  B2. 
Optimization  problem  5.1  can  now  be  exressed  as: 


Minimize  J  =  c^C 

Subject  to:  F  >  0,  C  >  0,  RiiCO  <  0^  (5.4) 


where  /2,(C,^)  is  given  by  either  Ri  or  R2  (equations  5.3  and  5.2).  Recall,  both  con¬ 
straints  are  equivalent.  To  simplify  notation,  the  dependence  of  the  matrix  functions 
on  C  and  ^  will  be  implicit  in  the  sequel.  The  controller  matrices  (Y,  W)  will  consis¬ 
tently  be  functions  of  ^  and  the  plant  matrices  (A,B\,B2)  will  always  be  functions 
of  C. 

As  can  be  seen  in  equation  5.3,  this  problem  is  affine  in  C  for  a  fixed  controller 
K  =  WY~^ ,  since  the  plant  itself  is  affine  in  C*  On  Ihe  other  hand,  equation  5.2 
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shows  that  for  a  fixed  plant  {A,Bi,  C,  D)  this  problem  is  affine  in  ^  .  Our  problem, 
however,  is  to  minimize  J  over  all  feasible  ^  and  Even  though  J  is  affine  in  it 
is  not  clear  whether  the  constraint  set  {$  =  (CO  •  C  >  Oi^(C»0  <  0}  is  convex. 
This  means  that  the  numerical  solution  of  the  optimization  problem  5.4  may  turn  out 
to  be  a  local  minimum.  An  important  area  of  future  research  will  be  to  determine 
whether  the  set  $  is  convex.  Presently  it  can  be  showr  that  for  a  special  case  of 
the  optimization  problem  5.4,  the  set  $  is  convex.  This  case  is  discussed  in  the  next 
section. 

1.  Special  Case:  Plant /Controller  Optimization  as  a  Generalized 
Eigenvalue  Problem 

Consider  a  single  parameter  plant  optimization  problem,  where 

A  =  Ao  +  C-Ai, 

52  =  B2o+(B2,.  (5.5) 

Suppose  the  matrix  pair  (A],  52, )  is  stabilizable.  A  physical  example  of  such  an  one 
parameter  problem  could  be  optimization  of  the  size  of  the  vertical  tail  of  an  aircraft, 
or  the  size  of  the  control  fin  on  a  missile  or  a  submersible.  Now  the  optimization 
problem  can  be  formulated  as  follows: 


Minimize  ;  ( 


Subject  to:  T  >  0,  C  >  0,  and 


5i  = 


(  AoY  +  YA'o  +  B^W  +  WB'^  +  5,5'  + 
V  CAiV'  +  yM', +52,H^  +  lV'5i,) 
(CY  ->rDW) 


) 


(CY  A- Dwy 

-/ 


<  0. 

(5.6) 


Let  t  denote  a  very  small  number.  Using  simple  algebra  and  the  definition  of  nega¬ 
tive  definiteness,  it  can  be  shown  that  optimization  problem  5.6  is  equivalent  to  the 


86 


following  problem: 


Minimize  :  ( 

Subject  to:  y  >  0,  C  > 

\ -{AtY  +  YA\+B2,W  +  W'B'^^)  O' 

L  0  . 

_\  AoY  +  YA^i  +  B^W +  WB'^  +  BiB[  [CY  +  DWy 
{CY  +  DW)  -I 

Problem  5.7  is  in  the  form  of  the  Generalized  Eigenvalue  Problem  (GEVP)  (see  2.1 
and  [Ref.  15]): 

Minimize:  A 

Subject  to:  \B(x)  —  A{x)  >  0, =  A{x)\B(x)  >  0,  C(a:)  >  0, 

where  A(x)^  B{x),  and  C{x)  are  afRne  in  x.  As  mentionned  in  Chapter  II,  the  GEVP 
is  a  quasi-convex  problem,  meaning  that  it  has  a  unique  global  minimum  which  can 
be  found  using  efficient  numerical  techniques  [Ref.  14,  15). 

2.  General  Case 

Unfortunately,  many  of  the  more  interesting  aircraft  optimization  problems 
cannot  be  reduced  to  GEVP  form.  This  is  particularly  true  for  the  case  where  several 
aircraft  parameters  have  to  be  optimized.  However,  the  optimization  problem  5.4  is 
affine  in  either  the  vector  of  plant  parameters  or  the  set  of  controller  parameters 
W  and  Y.  This  suggests  the  following  approach  to  solving  the  optimization  problem 
5.4:  find  a  controller  (holding  the  plant  constant)  ,  and  then  minimize  the  objective 
function  while  holding  the  controller  constant: 

1.  Fix  A{0,B{C).  Then, 

Minimize:  A  (over  ^), 

Subject  to:  [  ]  >  0.  (5.8) 
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2.  Fix  Then, 


Minimize:  J  (over  C)i 
J  —  c^C 

Subject  to:  |  0 

0 


0 

diag(C) 

0 


0 

0 

■R2(U) 


>  0. 


(5.9) 


3.  Go  to  step  1  until  exit  criteria  is  satisfied. 


Denote  tlie  value  of  A  obtained  in  the  first  step  as  the  controller  margin. 
Given  the  controller  determined  in  the  first  step,  the  second  step  of  the  procedure 
then  finds  the  feasible  plant  with  the  smallest  associated  cost.  The  procedure  quits 
when  the  controller  margin  becomes  so  small  that  the  numerical  procedure  either  fails 
to  find  a  new  feasible  controller  after  step  two,  or  step  two  is  numerically  unable  to 
further  refine  the  plant. 

The  controller  margin  has  a  very  rich,  significant  geometrical  meaning.  As 
the  maximum  eigenvalue  of  the  controller  margin  presents  the  “distance” 

of  from  singularity,  and  consequently  the  “distance”  or  margin  by  which 

the  closed-loop  system  satisfies  the  performance  specifications.  It  could  notionally 
be  considered  to  represent  the  “size”  of  the  set  of  feasible  controllers.  The  set  of 
feasible  controllers  is  either  empty  or  infinite,  so  “size”  is  used  loosely.  The  greater 
the  margin,  however,  the  greater  the  range  of  feasible  controllers.  This  is  important 
because  the  further  that  /?i(GO  is  from  singularity,  then  the  more  “room”  available 
for  the  second  phase  of  the  algorithm  to  optimize  the  plant.  One  would  intuitively 
expect  that  as  the  controller  margin  decreases,  then  the  amount  of  latitude  available 
to  optimize  the  plant  also  decreases. 

Note  that  both  steps  of  this  algorithm  are  EVP's  and  consequently  perfectly 
suited  for  solution  by  interior  point  methods.  Since  the  problem  is  affine  in  both 
steps  of  the  algorithm,  the  numerical  procedure  is  guaranteed  to  converge.  But,  as 
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discussed  earlier,  whether  the  problem  is  convex  jointly  in  the  controller  and  plant 
parameters  is  presently  not  known  and  is  subject  of  future  research.  Therefore,  there 
is  no  assurance  that  the  obtained  minimum  is  global  (unless  the  problem  satisfies  the 
conditions  of  the  special  case).  The  above  procedure  clearly  determines  a  valid  upper 
bound  for  the  joint  procedure,  since  a  solution  by  interior  point  methods  would  never 
leave  the  joint  feasible  set.  We  have  not,  however,  established  a  means  for  computing 
a  lower-bound.  This  too  is  an  issue  to  be  pursued  by  further  research. 

A  sequence  of  examples  will  demonstrate  the  viability  of  the  proposed 
methodology  and  illustrate  several  of  its  more  powerful  implications.  For  the  first 
several  examples,  a  single  plant  variable  is  optimized.  The  examples  build  in  complex¬ 
ity  as  the  methodology  is  expanded  to  accommodate  the  other  various  performance 
measures. 

Example  One-  Optimal  Vertical  Tail  at  a  Single  Flight  Condition 

This  very  simple  example  will  demonstrate  the  formulation  of  the  problem, 
as  well  as  some  of  the  properties  that  were  discussed  above.  Consider  the  directional 
dynamics  of  a  typical  fighter-size  aircraft.  The  most  simple  approximation  is  a  second 
order  system,  with  aerodynamics  providing  both  restorative  and  dissipative  forces. 
The  wing-body  combination  of  most  aircraft  is  sized  and  shaped  by  factors  such  as 
range,  maximum  speed,  payload,  powerplant.  Typically,  the  directional  dynamics 
of  the  wing-body  combination  include  both  a  stable  and  an  unstable  pole.  Given  a 
specific  wing-body  combination,  the  problem  for  the  aero  configuration  designer  and 
control  designer  is  to  determine  the  size  of  the  vertical  tail  and  controller,  which, 
together  in  feedback,  provide  satisfactory  dynamic  behavior.  For  simplicity,  we’ll 
consider  an  all-moving  tail  so  as  to  reduce  the  number  of  degrees  of  design  freedom 


89 


to  one.  Because  of  the  single  degree  of  freedom,  this  problem  is  quasi-convex  and  is 
know  a  priori  to  have  a  unique,  global  minima. 

The  governing  differential  equation  is: 

^  ^  -  yCnJ  +  -  C^6  .  (5,10) 

The  notation  here  is  standard  aeronautical  usage: 

w  :=  disturbance  input 

6  :=  control  deflection 

^  :=  sideslip  angle 

q  :=  dynamic  pressure 

S  :=  wing  reference  area 

b  :=  wing  span 

It  :=  moment  of  inertia  about  the  vertic. » (,5)  axis 

/(  :=  vertical  tail  lever  arm  (distance  from  CG  to  aero  center  of  tail) 

:=  non-dimensional  change  in  yawing  moment  per  radian  of  sideslip 
V  :=  aircraft  velocity 

(5.11) 

The  contribution  of  the  tail  and  wing/body  can  be  separated: 

Cn.  =  +  Ci^V  (5.12) 

where  V  =  is  defined  as  the  vertical  tail  volume.  Note  that  V  is  a  dimensionless, 
affine  function  of  the  vertical  tail  area  At  (or  /f!).  This  is  the  quantity  which  we  shall 
optimize.  Using  5.12,  5.10  can  be  rewritten  as  follows: 

I?  =/l  ■\-Biw-\-B26,  (5.13) 

where: 

A  —  i4u,fc  + 

0  I  ]  r  0  0  1 

gSbC„^^^  2Sbt,C„^^^  -I-  qSbCi^^  V,  (5.14) 

TT*^  77v^  77^  7;F^ 

=  Bi^  +  Bi,V 
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V 


(5.15) 


0 

0 

+ 

qSbCtg^ 

L  in  J 

L 

II 

+  B2,V 

■  0  ■ 

0 

0 

+ 

gSUiCtg^ 

1  1. 

(5.16) 


2gSbltCi. 

Note  that  for  this  problem,  A}  has  eigenvalues  at  zero  and - 771'  ^  ®)- 

The  following  numerical  values  were  obtained  using  stability  derivative  data 
from  [Ref.  37]  and  [Ref.  40]  for  a  fighter  aircraft  at  a  flight  condition  of  230  fps  at 
sealevel. 


A 

Bx 

B2 


0  1 
0.0103  0.0018 


0 

0.0004 

0 
0 


0 

-0.1765 


0 

-4.1044 


0  0 
-4.1044  -0.7067 

Iv 


V 


The  tail  volume  V  was  initialized  at  a  value  of  0.47. 

The  problem  was  to  determine  the  minimum  tail  volume  which  together 
with  the  feedback  controller  would  stabilize  the  plant,  and  would  limit  the  rms  ac¬ 
tuator  deflection  and  sideslip  to  ten  and  two  degrees,  respectively,  in  the  presence 
of  moderate  turbulence.  MIL-8785C  establishes  moderate  turbulence  as  10  fps  at 
sealevel.  Bx  is  scaled  by  a  factor  of  lO/ps/230/ps  to  normalize  the  ^ms  value  of  w  to 
1  radian.  Since  the  outputs  of  interest  are  0  and  6,  the  synthesis  model  is  completed 


by: 


y  = 


'  0' 

■  57.3/10  0  ■ 

f^l  + 

0 

6 

0  0 

57.3/2 

(5.17) 


The  output  signals  have  likewise  been  scaled  to  guarantee  that  an  rms  output  of  1 
rad  satisfies  the  performance  requirements. 

An  interior  point  method  was  used  to  perform  the  optimization  problem 
of  posed  by  algorithm  5.8  and  5.9  to  determine:  (a)  the  smallest  vertical  tail  vol- 
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Figure  5.1:  Optimization  History  for  Tail  Volume  (Example  One) 

ume,  and  (b)  the  associated  state-feedback  controller  which  satisfied  the  performance 
requirements.  Recall  that  the  design  of  a  controller  which  satisfies  an  Hoc,  bound 
implicitly  satisfies  internal  stability.  The  final  required  tail  volume  was  V  =  0.0250, 
and  the  associated  controller  was  K  ==  [5.443  10.467]. 

Figure  5.1  depicts  the  progress  of  the  optimization  algorithm,  with  the 
algorithm  commencing  in  the  top  right  corner.  Note  that  the  cost  and  the  controller 
margin  decreased  monotonically  with  each  iteration.  For  a  single  variable  problem, 
the  weight  was  set  to  one,  so  that  the  plant  cost  was  identically  equal  to  the  tail 
volume.  The  algorithm  forces  the  cost  to  decrease  monotonically  since  the  terminal 
cost  at  the  end  of  each  step  is  then  the  starting  cost  for  the  commencement  of  the 
next  iteration.  For  a  single  plant  variable,  the  controller  margin  would  be  expected 
to  decrease  monotonically,  since  the  margin  reflects  the  size  of  the  set  of  feasible 
controllers.  Since  was  not  stable,  then  the  open-loop  poles  predictably  moved  to 
the  right  as  V  was  decreased.  Consequently,  as  the  poles  of  the  open-loop  plant  shifted 
to  the  right,  the  set  of  feasible  controllers  would  be  expected  to  monotonically  shrink 
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as  well  (this  was  not  true  for  multi-variable  problems,  as  will  be  shown  later).  The 
process  was  terminated  when  the  numerical  routines  either  1)  could  not  find  a  feasible 
controller  during  step  1;  or  2)  the  controller  margin  exiting  step  2  was  too  small  to 
numerically  permit  further  refinement  of  the  plant.  In  this  particular  example,  the 
graph  clearly  depicts  the  minimum  bound  achievable  by  this  method. 

This  example  clearly  demonstrated  the  viability  of  the  general  method.  It 
was,  however,  limited  in  its  applicability,  since  it  only  provided  the  size  of  the  tail 
volume  required  at  a  single  point  in  the  operating  environment,  and  the  fulfillment 
of  a  single  performance  criteria.  The  challenge  for  the  configuration  designer  is  the 
determination  of  the  optimal  plant  which  satisfies  diverse  performance  requirements 
at  all  points  within  the  operating  envelope.  The  next  section  will  show  how  the 
method  easily  expands  to  accommodate  additional  constraints. 

3.  Plant/Controller  Optimization  with  Multiple  Joint  Hoc  Con¬ 
straints 

Consider  now  the  problem  of  finding  the  optimum  size  of  the  vertical  tail 
which  will  satisfy  three  different  Woo  performance  requirements  at  distinct  flight 
conditions.  Many  of  the  plant  variables  in  equation  5.16  are  dependent  on  the  flight 
condition,  including  the  moment  of  inertia,  the  dynamic  pressure  and  the  stability 
derivatives.  The  plant  matrices  may  consequently  be  dramatically  different.  Let 
Q  i(C)>  Q  2(C)i  J^nd  Q  i(C)  represent  the  aircraft  dynamics  of  a  single  configuration, 
but  at  three  separate  flight  conditions.  Let  4, 1  and  I  represent  the  controllers  that 
satisfy  the  three  distinct  Woo  performance  requirements  represented  by  i)  <  0; 

^  A 

^2(C»0  <  0;  ^3(CiO  <  0-  These  three  independent  W,o  requirements  will  be 
satisfied  if : 

■  RxiU)  0  0 

0  R2{U)  0  <0.  (5.18) 

0  0  RzicA). 
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The  optimization  problem  can  therefore  be  formulated  as  follows: 

Minimize:  J  = 

Subject  to:  <  0,  (  >  0. 

This  problem  is  afRne  in  the  plant  variable  (  for  fixed  controllers,  and  affine  in  the 

«  A 

controller  variables  (,  and  {  for  a  fixed  plant.  The  solution  to  this  problem  is  the  op¬ 
timal  plant  which  permits  satisfaction  of  each  of  the  three  performance  requirements, 
and  each  of  the  three  associated  controllers.  The  problem  strategy  is  similar  to  that 
pursued  above  with  only  minor  modification.  Since  the  three  controller  solutions  are 
independent,  they  can  be  determined  independently  to  save  computational  cost,  with 
the  plants  fixed. 

Example  Two-  Optimal  Vertical  Tail  at  Multiple  Flight  Conditions 

To  demonstrate  the  multiple  flight  condition  problem,  the  following  three 
flight  conditions  were  chosen  for  the  aircraft  in  the  Example  1:  230  fpa  at  sealevel, 
876  fps  at  35  A'/t,  and  1742  fps  at  55  Kft.  These  conditions  correspond  to  the 
approach,  subsonic  cruise,  and  supersonic  dash  mission  phases.  Models  were  again 
synthesized  from  [Ref.  37]  and  [Ref.  40).  The  horizontal  gust  magnitude  was  10 
fps  at  sealevel,  and  5  fps  at  the  other  two  conditions.  Identical  constraints  on  the 
performance  outputs  were  imposed  (2  degrees  of  rms  sideslip  and  10  degrees  of  rms 
tail  deflection). 

Figure  5.2  depicts  the  progress  of  the  algorithm.  Note  that  one  flight 
condition  dominates  the  process,  and  the  algprithm  quits  when  the  controller  margin 
is  exhausted  at  the  slow  speed  flight  condition.  Intuition  is  confirmed  in  that  for 
a  single  variable  problem,  one  would  expect  the  limiting  tail  volume  to  be  identical 
to  the  greatest  of  the  three  tail  volumes  when  calculated  Independently.  The  three 
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Figure  5.2:  Optimization  History  Multiple  Flight  Conditions  (Example 
Two) 

resulting  controllers  were:  Kgiow  =  [5.443  10.467],  Ktuktonic  =  [31.396  33.350),  and 
supersonic  =  [38.647  37.949).  This  single  procedure  therefore  results  in  an  optimal 
plant  conhguration  and  the  necessary  controller  for  each  operating  point. 

The  physical  structure  of  our  methodology  thereby  accommodates  the  sim¬ 
ple  inclusion  of  multiple  plant  operating  conditions  by  direct  diagonal  augmentation 
of  the  constraint  matrix  functional.  The  number  of  flight  conditions  is  limited  only 
by  one’s  patience  in  waiting  for  the  computational  outcome,  and  the  ability  of  the 
numerical  routines  to  find  viable  answers. 

D.  APPLYING  JOINT  DISTURBANCE  REJECTION/  STABILIZA¬ 
TION  REQUIREMENTS 

Now  consider  a  problem  in  which  the  disturbance  rejection  requirement  is  im¬ 
posed,  along  with  a  requirement  that  the  closed-loop  poles  be  placed  in  a  specified 
circle.  The  Hoo  norm  will  again  be  used  to  impose  the  disturbance  rejection  require¬ 
ment.  Note  that  minimizing  the  control  power  subject  to  a  pole- placement  require- 
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ment  is  not  by  itself  an  interesting  problem.  Intuitively,  some  constraint  on  actuator 
activity  is  mandatory  in  the  problem  formulation.  Otherwise,  the  solution  would 
simply  allow  actuator  activity  (repre.sented  by  the  state-feedback  gain)  to  increase  in 
an  unbounded  fashion  to  compensate  for  the  decrease  in  control  power. 

Let  Q  and  r  define  a  circle  of  radius  r  centered  at  9  =  —{a  -f  r).  As  discussed  in 
Chapter  III,  the  poles  of  (A  -|-  BjA')  are  in  the  circle  defined  by  o  and  r,  if  and  only 
if  there  exists  a  positive  definite  solution  V  =  >  0  such  that  the  following  matrix 

inequality  is  satisfied: 

5(C,0  <  0  (5.19) 

where, 

S(ca  :=  (A  +  B,K  +  aI)y  +  y(A  +  B2K  +  a/f 

+(A  +  B2K  -I-  a/)( V/r){A  -f  B^K  +  alf.  (5.20) 

Using  the  substitution  K  =  Wy~\  this  expression  is  equivalent  to  both  of  the 
following  matrix  inequalities,  by  Schur  complements: 


^•i(C,0  := 

(  {A  +  al)y  -I-  y{A  +  alf  +  {A  +  aI){yir)(A  -I-  o/)^-|-  \  „  ^ 

\  B2W{(A  +  aI)/r  + If +  ({A  +  aI)/r+ DW^BJ  ) 

(BiWf  -yr 


<0 

(5.21) 


and 


S2{C,0  ■= 


{A  +  B2K  -I-  al)y  +  y{A  -b  B2K  -I-  Qlf  (A  +  B2K  4-  al) 

(A  -I-  B2K  -b  alf  — inv(K/r) 


<  0 


(5.22) 

The  5’i(C,0  is  affine  in  and  52(C,0  i®  affine  in  Ci  but  neither  is  affine  in  both.  Since 
the  two  expressions  are  equivalent  we  can  alternatively  use  them  for  the  controller 
design  and  the  plant  optimization.  The  mechanics  of  constraining  the  problem  to 
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simultaneously  satisfying  both  the  pole  placement  requirement  and  the  Hoo  bound,  is 
analogous  to  the  multiple  flight  condition  problem  described  previously.  The  problem 
can  be  stated  as: 


Minimize:  J  = 
Subject  to:  T{C,,0  := 


R[U)  0 

0  S{U) 


<  0,  and  C  >  0. 


(5.23) 


Here,  we  again  employ  our  prior  approach  of  dividing  the  problem  into  two  LMI 
sub-problems.  Define  two  matrix  inequalities: 


7’i(C,0:= 

RAU) 

0 

0 

.?,(C,0. 

<  0 

(5.24) 

7’2(C,0:= 

■  «2(C,0 
0 

0 

S2(ca 

<0 

(5.25) 

We  now  propose  the  following  algorithm: 


1.  With  (  fixed, 


Minimize:  A,  (over 

XI -Tx  0 


Subject  to: 


0 


>0. 


2.  With  optimal  4  from  step  1, 


Minimize:  J,  (over  C) 
J  - 

Subject  to 


0 


0  diag(C) 

0  0 


0 

0 

-T2 


>  0. 


3.  Iterate  until  termination  criteria  satisfied. 


Due  to  the  affine  problem  formulation,  both  steps  may  be  solved  by  either  inte¬ 
rior  point  or  convex  methods.  The  Hoo  constraint  and  the  pole  placement  constraint 
are  just  two  examples  of  constraints  that  can  be  expressed  as  LMI’s.  Consequently, 
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this  method  of  diagonally  augmenting  constraints  to  achieve  a  joint  constraint  can 
be  used  with  as  many  jointly  feasible  diverse  constraints  as  desired.  Examples  might 
include  the  intersection  of  several  circles,  or  distinct  Tioo  'Woo  bounds.  We  will 
later  formulate  the  Woo  /  Woo  problem  in  providing  for  distinct  Woo  bounds  on 
robustness  and  on  performance. 

Example  Three-  Vertical  Tail  Optimization  with  Joint  Constraints  (  Woo  ond  Pole 
Placement) 

Consider  again  the  single  flight  condition  problem  from  example  1,  retaining  the 
disturbance-to-output  performance  criteria.  MIL-8785C  requires  that  the  closed-loop 
dutch-roll  frequency  exceed  1  rad/sec  and  that  the  damping  ratio  exceed  0.15.  These 
requirements  can  be  (conservatively)  satisfied  by  constraining  the  poles  to  a  circle  of 
radius  87.3,  and  centered  at  (-88.3,0).  By  jointly  posing  these  constraints  using  the 
above  formulation,  the  plant  optimization  problem  was  solved  using  interior  point 
methods.  The  resulting  optimal  tail  volume  was  V  =  0.0383,  with  an  associated 
controller  K  =  [15.96  18.91].  The  resulting  poles  were  at  —1.500  ±  0.637j  (inside 
the  circle).  Figure  5.3  depicts  the  progress  of  the  algorithm.  Note  that  the  addition 
of  the  pole  placement  constraint  required  a  larger  tail  volume  than  was  achieved  in 
Example  1  for  the  Woo  constraint  alone,  where  V  =  0.0253  was  required. 

A  significant  attribute  of  this  problem  is  that  unlike  the  previous  two,  this 
example  (or  any  problem  with  joint  constraints)  could  not  have  been  be  solved  by 
bisection  on  (  and  a  standard  Riccati  based  Wo©  controller  design.  We  have  now 
demonstrated  how  the  methodology  accomodates  both  stabilization  and  disturbance 
rejection  specifications.  Next,  we  will  demonstrate  the  inclusion  of  open-loop  maneu¬ 
verability  specifications  into  the  problem  methodology. 
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Figure  5.3:  Optimization  History  for  Joint  Hcx>  /  Pole-Placement  (Exam¬ 
ple  Three) 

E.  INCLUDING  MANEUVERABILITY  REQUIREMENTS 

This  section  presents  several  methodologies  by  which  open-loop  maneuverabil¬ 
ity  requirements  can  be  expressed  as  LMI’s.  Maneuverability  requirements  are  very 
much  unlike  disturbance  rejection,  where  the  closed-loop  plant  must  demonstrate  a 
maximum  acceptable  level  of  attenuation  in  the  presence  of  disturbances.  Instead, 
maneuverability  requirements  demand  that  a  system  demonstrate  a  minimum  ampli¬ 
fication  in  the  presence  of  a  command  signal:  Consider  the  open-loop  system  depicted 
by  Figure  5.4,  A  typical  maneuverability  specification  has  the  following  form:  given 
a  maximum  control  input  u  =  Ihe  steady  state  response  of  a  scalar  output  r 

must  exceed  a  certain  threshold,  r^^^rel  .  Note  that  u  may  be  a  vector  of  all  relevant 
control  surfaces. 

Alternatively,  consider  the  closed-loop  system  of  Figure  5.5.  The  maneuver¬ 
ability  specifications  above  could  equivalently  be  expressed  in  the  context  of  this 
closed-loop  system:  Given  an  input  reference  signal  remd  of  magnitude  rthrt$t  the  out- 
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Figure  5.4:  Open>loop  Formulation  for  Maneuverability  Constraints. 


Figure  5.5:  Closed-Loop  Formulation  for  Maneuverability  Constraints. 

put  rerror  =  T  —  Tcmd  tnust  be  zcTo  in  Steady  state,  and  the  control  inputs  Ui  must  not 
exceed  Umax:,  in  steady  state. 

Maneuvering  specifications  fall  into  two  general  classes,  for  which  each  of  these 
formulations  are  helpful  in  posing  the  requirements  as  LMI's.  As  examples,  consider 
two  different  longitudinal  maneuverability  specifications  for  a  tactical  aircraft  with 
canards,  stabilators  and  thrust  vectoring  as  longitudinal  control  effectors.  In  the 
first  case,  sufficient  control  power  might  be  required  to  provide  at  least  9  ^’s  at  a 
specific  flight  condition,  with  all  effectors  fully  deflected  or  deflected  no  further  than 
some  effective  limit  (aerodynamic  surfaces  may  lose  effectiveness  long  before  reaching 
a  physical  actuator  limit).  Alternatively,  a  requirement  might  be  that  the  sum  of 
the  effectors  generate  a  pitch  acceleration  of  at  least  0.25  rad/s  at  full  deflection  at 
a  specified  flight  condition.  Both  of  these  types  of  design  specifications  exist.  The 
output  r  in  either  case  would  be  scalar,  while  the  input  u  would  be  a  vector  of  the 
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three  control  effectors. 

To  understand  the  difference  between  these  two  types  specifications,  consider 
the  state  space  representation  of  the  open-loop  system  depicted  by  Figure  5.4: 

'x  =  A(Ox  +  B2(()u 

g  =  i  2  =  C(C).r  -I-  0(0X1  .  (5.26) 

r  =  z 

Let  Topen  denote  the  transfer  matrix  from  ti  to  r  in  Figure  5.4.  Then  it  hzis  the 
following  form: 

■■  r(3)  =  {C(()(a;  -  +  D(C)}  ti(s).  (5.27) 

For  the  examples  we  cited  above,  if  r  is  the  pitch  acceleration,  then  D  is  non-zero,  and 
C  is  zero,  annulling  the  first  term  of  the  transfer  function  matrix.  On  the  other  hand, 

if  r  is  the  load  factor,  then  the  D  matrix  of  the  above  open-loop  system  is  zero.  The 

first  case  can  be  considered  a  static  maneuverability  specification,  while  the  second 
one  a  dynamic  maneuverability  specification.  We  will  see  that  a  static  maneuverability 
requirement  is  easily  posed  as  an  LMI.  In  the  case  of  dynamic  specifications,  however, 
both  the  closed-loop  and  open-loop  formulations  can  be  useful. 

1.  Static  Maneuverability  Requirements 

First,  let  us  consider  the  static  maneuverability  requirements.  These  in¬ 
clude  constraints  where  the  modeled  open-loop  system  has  a  non-zero  D  and  zero  C 
matrices.  An  LMI  formulation  for  the  requirement  is  evident  by  inspection: 

^(C)«max  -  rthres  >  0.  (5.28) 

Multiple  similar  requirements  could  be  diagonally  stacked.  This  type  of  specifica¬ 
tion  can  also  referred  to  a  static  control  power  constraint,  because  it  frequently  is 
expressed  as  the  static  moment  required  from  a  controller  or  set  of  controllers  at  a 
specified  condition.  These  conditions  can  either  be  equilibrium  or  non-equilibrium. 
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I'he  specification  itself  can  have  units  of  force  or  moment,  or  translational  or  an¬ 
gular  acceleration  in  response  to  a  limit  control  deflection.  The  next  example  will 
demonstrate  how  specifications  of  this  type  can  simply  be  accommodated  by  our 
methodology. 

Example  Four-  Vertical  Tail  Optimization  with  Static  Moment  Requirements 


A  specification  that  frequently  sizes  vertical  control  surfaces  is  the  require¬ 
ment  that  adequate  control  power  be  available  to  balance  the  moments  generated 
by  adverse  thrust  conditions,  such  as  engine  out.  Consider  the  vertical  tail  sizing 
problem  discussed  above.  In  addition  to  the  previous  Hra  specification  for  turbu¬ 
lence  rejection  and  stabilization,  let  us  now  also  impose  the  static  requirement  that 
the  tail  be  sized  so  as  to  be  able  to  generate  a  moment  adequate  to  balance  40,000 
ft  —  lb  of  torque  at  full  deflection  (30  degrees)  at  our  nominal  flight  condition.  This 
requirement  is  representative  of  the  torque  necessary  to  balance  an  asymmetric  thrust 
condition.  Furthermore,  it  can  simply  be  posed  as  the  following  LMI: 

^i<a<ic(V)  ;=  ^thre§  ^  0,  (5.29) 

where  Umax  =  0.52  rad,  and  rihrti  =  40,000  ft  —  lb. 

Let  ^  =  V.  Since  the  constraint  /?,«ouc(0  >  0  is  not  relevant  to  the 
search  for  a  feasible  feedback  controller,  it  does  not  need  to  be  considered  during  the 
controller  optimization  phase  of  the  process.  Therefore,  the  algorithm  can  now  be 
posed  as  follows: 

1.  With  C  fixed. 


Minimize:  A,  (over  f) 


Subject  to: 


0 


0 

Y 


>0. 
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2.  With  optimal  (  from  step  1, 


Minimize:  J,  (over  0 
J  - 

n  •  .  I  0 

Subject  to;  |  ^ 

0 


0 

diag(C) 

0 

0 


0  0 

0  0 

-R2  0 

0  D,tatic(0  J 


>0. 


3.  Iterate  until  termination  criteria  satisfied. 


Figure  5.6  depicts  the  progress  of  the  algorithm,  with  the  starting  point  at 
the  upper-right  end  of  the  trace.  This  graph  depicts  two  significant  issues.  First  of 
all,  the  final  required  value  was  V  =  0.14,  rather  than  the  value  of  0.025  which  was 
required  when  the  Hoo  constraint  alone  was  applied.  This  answer  is  in  fact  identical 
to  that  obtained  if  we  had  alternatively  solved  the  linear  equation: 

—  Vihres  ~  0. 

Secondly,  the  controller  margin  at  the  conclusion  of  the  optimization  is  several  orders 
of  magnitude  greater  than  that  for  any  of  the  previous  problems.  This  indicates 
that  the  set  of  feasible  controllers  is  comparatively  large,  and  that  the  final  answer 
was  independent  of  closed-loop  dynamic  issues  and  was  instead  driven  by  the  open- 
loop  maneuverability  requirement.  This  is  consistent  with  the  industry's  practical 
experience  that  directional  control  power  is  generally  sized  by  considerations  such  as 
thrust  asymmetry  rather  than  turbulence  rejection. 

The  kink  in  the  plot  for  the  joint  specification  is  caused  by  the  nature  of 
the  graph.  The  x-axis  reflects  the  result  of  the  controller  optimization  phase  of  the 
algorithm,  while  the  y-axis  reflects  the  result  of  the  plant  optimiztion.  The  static 
maneuverability  constraint  is  only  applied  during  the  latter  phase,  and  so  when  the 
static  constraint  boundary  is  reached,  the  controller  phase  finds  a  new  controller  with 
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Figure  5.6:  Optimization  History  for  Vertical  Tail  Volume  with  Static 
Constraint  (Example  Four) 

a  smaller  control  margin,  but  the  plant  optimization  phase  can  not  decre£tse  the  plant 
cost  any  further.  The  result  is  an  abrupt  kink  in  the  plot. 

We  have  consequently  demonstrated  how  static  maneuverability  specifica¬ 
tions  can  be  accommodated  into  the  methodology. 

2.  Dynamic  Maneuverability  Requirements 

Now  consider  the  problem  of  posing  dynamic  maneuverability  specifica¬ 
tions,  where  for  the  open-loop  system  D  =  0,  and  C  is  a  rank  one  row  vector.  As 
mentionned  above,  these  types  of  requirements  can  be  posed  either  in  an  open-loop 
or  closed-loop  formulations. 

a.  Dynamic  Maneuverability  Requirements:  Closed-Loop  For¬ 
mulation 

We  will  first  show  how  a  maneuverability  specification  can  be  posed  as 
an  LMl  by  means  of  the  closed-loop  formulation.  Let  Tu,u>{Q  X  )  represent  the  closed 
loop  transfer  function  from  exogeneous  disturbance  w  =  r  to  the  control  command 
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Uj.  Here  we  are  interested  in  the  steady  state  response  of  the  control  command  u,-  to 
the  constant  disturbance  input  w  =  rthrts-  In  particular,  absolute  value  of  «,•  must 


not  exceed  Umax,  in  the  presence  of  tv  =  rthre$’ 


«.(«) 


u>(s) 


u 


maXt 


(5.30) 


lj=0  ^thret 

Two  approaches  were  considered  for  formulating  this  constraint  as  an  LMI. 

(1)  An  Hoo  Approach 

First,  using  the  power  interpretation  of  the  Hoo  norm  for  a  sta¬ 
ble  SISO  system,  this  requirement  can  be  rewritten  as  a  constraint  on  the  Hoo  norm 
ofT„,,„(a,C): 

n.YslI  11 _ 

(5.31) 


u;(s) 


<  \\Ta.U6  iC  )l|oo  < 

,_0  rtkret 


Notice,  if  the  Hoo  norm  of  Tu,w(G  )  occurs  at  a  frequency  other  than  zero,  the 
constraint  5.31  provides  only  a  sufficient  condition  for  meeting  the  requirement  5.30. 
However,  it  has  been  our  experience  that  for  the  class  of  problems  involving  integral 
control,  the  'Hoo  norm  of  Tuiw(G  X  )  occurs  at  the  origin. 

Consequently,  the  Hoo  specification  previously  applied  for  dis¬ 
turbance  rejection  can  now  be  also  applied  to  meet  dynamic  maneuverability  require¬ 
ments.  Depending  on  the  problem,  these  requirements  must  be  satisfied  at  the  same 
flight  condition  as  the  disturbance  rejection  requirements  (by  including  the  command 
signal  in  the  exogenous  input  vector  w),  or  at  a  different  more  critical  for  maneuver¬ 
ability  condition. 


Example  Five-  Optimization  of  Multiple  Surfaces  with  Open  and  Closed-Loop  Perfor¬ 
mance  Requirements 


This  example  problem  has  several  objectives.  First  of  all,  it  is 
a  problem  where  the  cost  function  is  dependent  upon  multiple  plant  parameters  and 
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thus  provides  a  much  more  rigorous  test  of  the  proposed  methodology.  Secondly,  a 
multiple  variable  problem  permits  using  a  variety  of  the  initial  values  for  the  plant  pa¬ 
rameters.  This  will  help  determine  whether  the  algorithm  will  terminate  at  different 
answers,  perhaps  giving  some  insight  into  the  convexity  of  the  multiparameter  prob¬ 
lem.  Recall,  the  problem  is  convex  in  the  single  parameter  case.  Finally,  a  problem 
was  needed  with  both  open  and  closed-loop  performance  requirements. 

Because  of  the  availability  of  component  stability  derivative  data 
for  the  F-I4  aircraft,  a  longitudinal  control  problem  similar  to  the  one  in  Chapter  IV 
was  selected.  The  vehicle  parameters  to  be  optimized  were  the  normalized  control 
powers  of  both  the  horizontal  stabilators,  and  the  direct  lift  control  (DLC).  Conse¬ 
quently,  let  the  vector  of  plant  parameters  4'  be  defined  as: 


C  =  (Ci,  Gf- 


Cl 


DLC 


Cl 


Cl 


The  cost  function  weights  on  the  plant  parameters  were  arbitrarily  chosen  to  be 
c  =  [3,  1]^.  Recall,  these  weights  can  represent  normalized  cost  in  dollars,  weight 
in  pounds,  etc.  The  reference  input  of  interest  was  commanded  flight  path  angle  7, 
and  the  outputs  to  be  regulated  were  the  actuator  deflections,  the  angle  of  attack 
error,  and  the  flight  path  angle  error.  The  disturbance  input  v  as  a  vertical  gust.  The 
control  inputs  were  stabilators  and  DLC  deflection  (thrust  was  assumed  constant), 
and  the  full  state  vector  was  assumed  to  be  available  for  feedback.  Thus,  the  problem 
was  stated  as: 


Find  the  plant  parameters  (()  and  a  state- feedback  controller  (^)  which 
minimize  the  total  cost  J  =  c^C  of  the  longitudinal  control  effectors, 
subject  to  the  following  dynamic  requirements: 

•  Step  response —  The  controller  must  track  a  step  flight  path  angle 
command,  7cmdi  with  no  steady  state  error  in  a  or  7. 
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•  Closed-loop  stability —  The  closed-loop  system  must  be  stable. 

•  Closed-loop  performance —  In  the  presence  of  a  vertical  gust  distur¬ 
bance,  Wgutt,  with  a  magnitude  of  5  fps,  the  stabilator  deflection 
should  not  exceed  20  degrees,  the  DLC  deflection  should  not  exceed 
40  degrees,  and  the  angle-of-attack  error  should  not  exceed  1.5  de¬ 
grees  (all  quantities  rms). 

•  Open-Loop  maneuverability —  The  plant  must  be  able  to  generate  a 
flight  path  angle  (7  =  — q)  of  3  degrees  with  the  DLC  and  stabilator 
deflected  no  more  than  40  degrees  and  20  degrees,  respectively. 


These  requirements  can  be  satisfied  by  the  joint  imposition  of 
the  following  Hoo  constraints: 

1.  The  step  response  requirement  will  be  satisfied  if  and  only  if 
l|r.„.„.(C  X  )|U  <  00,  where  :=  [^, 


2.  The  closed-loop  performance  will  be  satisfied  if  and  only  if 


X  )||oo  <  7^1  where  22  == 
bfps 


^Mtab  ^DLC  O 


iT 


20  deg'  40  deg'  1.5  deg 


3.  The  open-loop  maneuverability  requirement  will  be  satisfied  if 

,C  )|U  <  where  r,  .=  1^,  . 

A  sufficient  condition  then  for  the  satisfaction  of  these  three  constraints  is  the  single 
constraint:  ,C  )||oo  <  L  where 

tu  :=  IcmdV  =  [5  fps^  3  deg]"^ 

y  f  SnLC  Of  Oferror  *ygrror  lT 

^20  deg  ^  40  deg  1,5  deg  ^  C|«  '  C2»  ^  ' 
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and  Cl  and  cj  are  any  finite  positive  numbers.  This  constraint  also  implicitly  guaran¬ 
tees  internal  stability.  This  constraint  later  leads  to  the  formulation  of  the  synthesis 
model. 

The  choice  of  optimization  parameters  was  driven  by  the  unusual 
character  of  the  Direct  Lift  Control.  This  is  significant  because  the  DLC  control 
power  is  neither  linear  in  deflection  nor  proportional  to  the  size  of  the  DLC  surfaces. 
Consequently,  we  must  optimize  a  metric  whose  influence  on  the  plant  dynamics  is 
linear.  Normalized  control  power  was  therefore  chosen  as  the  optimization  parameter 
in  order  to  adhere  to  the  assumption  that  the  plant  dynamics  be  reasonably  modeled 
by  a  linear  system.  In  the  actual  aircraft  implementation,  the  controller  will  have  to 
include  a  nonlinear  schedule  on  the  DLC  deflection  in  order  to  achieve  the  commanded 
control  power.  Since  the  stabilators  are  a  conventional  aerodynamic  surface,  their 
control  power  is  in  fact  linear  with  both  deflection  and  surface  area,  and  any  one  of 
several  optimization  parameters  could  have  been  chosen  (tail  volume,  surface  area,  or 
absolute  control  power).  To  facilitate  the  comparison,  normalized  control  power  was 
chosen. 


To  proceed  with  the  problem  description  we  need  to  define  the 


following 

terms  using  flight  dynamics  conventions: 

u 

:= 

aircraft  velocity  resolved  in  the  body  x-axis 

a 

:= 

angle  of  attack 

H 

;  = 

pitch  rate  about  body  y-axis 

e 

:= 

pitch  attitude 

Cx, 

'= 

M. 

dy 

non-dimensional  trimmed  force/moment  coefficient, 
where  X  is  lift  (L),  drag  {D)  or  pitching  moment  (M) 

CXy 

:= 

ax 

dy 

non-dimensional  stability  derivative, 
where  y  ^  f  is  a  nondimensional  state  or  control  deflection 

Q 

:= 

dynamic  pressure 
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5  :=  wing  reference  area 

c  :=  wing  mean  chord 

m  ;=  mass 

lyy  moment  of  inertia  about  the  lateral  (y)  axis 

V  :=  aircraft  velocity 

Oq  :=  turbulence  variance 

:=  maximum  flight  path  angle  command  amplitude 

Ltab  •=  —.Jittak  stabilator  lever  arm  (distance  from  CG  to  aero  center  of  stab) 

Next,  the  aircraft  stability  derivatives  were  expressed  as  the  sum  of  their  wing/body 

{wb),  stabilator  (stab),  and  DLC  contributions  [Ref.  40]: 


;= 

(5.32) 

:= 

^La 

(5.33) 

:= 

Ca/o  Llofc  ^L,tah 

(5.34) 

:= 

Cl^  -  2  Ittab 

(5.35) 

:= 

+  2  lltab  C’l,,.* 

(5.36) 

;= 

Cl„  +  2  Ittab 

(5.37) 

:= 

(5.38) 

Note  that  since  the  DLC  perturbs  the  nominal  flow  field,  it  has  no  contribution  to  the 
A  matrix,  but  instead  represents  raw  control  power,  influencing  only  the  B  matrix. 

The  linear  aerodynamic  model  of  F*14  is  derived  next,  followed 
by  an  outline  of  how  it  was  used  to  form  a  synthesis  model.  The  state  derivatives 
of  the  core  aerodynamic  plant  were  i  =  [u  o  q  9^ •  Let  T  be  a  rotation/scaling 
matrix: 

—  cos(ao)  sin(Qo)  0 

T:=QS  -sin(ao)  -cos(qo)  0  , 

0  0  c  _ 

where  qq  is  the  trimmed  value  of  o. 
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Let  Im  represent  the  inertia/  a  matrix.  Then 


•  mV 

* 

0 

0 

01 

0  ■ 

/m:= 

mV 

C  rp 

2V^ 

0 

Cl^  0 

0 

lyy 

0 

Cm^  0  . 

0 

1  . 

0 

0 

0 

Now,  the  state  matrices  of  the  plant  have  the  following  form: 
■^aero  —  ^aeroo  "i”  ^oeroiCl  "h  ^oerojCs 


= 


+/ 


-1 

m 


12Ca/.+Cw.V-> 
0  0 


Cl 


'«tab 


0 

0 

0 


0 

0 


0 

1 

^»tab 

0 


0 

0 


2%* 

ofiL* 

i  2V 


0 

+ 

iV  sin(Q(o) 

V'  cos(qo) 

0 

0  1 

0 

1 

\ 

O 

o 

0 

0 

Cl  +  Cldic 

0  0 
0  0 

0 

1 

o 

o 

—Tngcos{9o) 
— mg  s\n{0o) 
0 


0 

0 

0 

0 


15.391 


B 


aero 


Baeroo  ■^oeroiCl  "i"  ^aerojC^ 


■  0  0  ■ 

• 

■  0 

0  ■ 

• 

0  0 

Cl.,.,  T 

1 

0 

0  0 
.00. 

L-U6  oj 
0 

0  . 

■ 

■  0 

CddlcICldlc 

■ 

CldlcT 

0 

1 

0 

CmdlcIClolc  . 

0  0 

(5.40) 


Note  that  these  matrices  include  dynamic  coupling  and  gravity  terms,  as  well  as 
the  aerodynamic  forces.  This  model  was  verified  by  comparison  with  the  nominal 
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state  matrices  ((  =  [1,  1]^)  obtained  from  the  linearization  of  the  nonlinear  model 
described  in  Chapter  IV. 

Using  the  aerodynamic  plant  matrices  above,  a  synthesis  model 


Q  was  formed: 


Ax  +  Biw  +  B2U 
Cx  +  D2UU 


with  w  and  z  defined  above,  and  and 


A  = 


B,  = 


B2  = 


C  = 


D2  = 


•aeroo 


0100 

0-101 


(TaAaerof^i’^  2) 


0 

0 


0  0 
0  0 
0  0 
0  0 
0  0 
0  0 

0 
0 
0 
0 
0 


•oeroi 


0  0  0  0 
0  0  0  0 


0  ■ 

^o^nefoo(">  2)  Q 

+ 

0 

0  0 

o 

O 

0  0 
0  0 
0  0 
0  0 
0  0 
0  0 


Cii 


0 


0 

0 

0 


0 

1 

UmoT] 

0 

0 


Cl,  (5.41) 


(5.42) 


Baeroi  1 

r  Batroj  1 

0 

0 

Ci  + 

0 

0 

C2, 

(5.43) 

0 

0 

1 

1 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

1 

0 

0 

0 

0 

(5.44) 

0 

0 

0 

0 

0.00001 

0 

0 

0 

0 

0 

0 

0.00001 

(5.45) 


Note,  the  second  column  of  A  shows  up  in  B\  because  the  plant 
sees  a  sharp  edged  perturbation  in  the  vertical  airmass  (6xv)  as  a  perturbation  in 
angle  of  attack  (6a  =  SwfV).  (Here  /l(:,2)  represents  the  second  column  of  A). 
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Note  that  the  elements  of  w  were  scaled  by  <t,  to  achieve  ||w||2  <1.  As  a  result, 
the  synthesis  model  was  scaled  to  ensure  that  any  state- feed  back  controller  C  =  K 
satisfying  ||7’2  u(^  ,C  )||oo  <  1  also  satisfies  each  of  the  specified  design  requirements. 
The  scaling  of  the  integral  errors  was  chosen  to  be  small  (1  x  10"®)  in  order  to  limit 
the  conservatism  of  the  Hoo  constraint.  Adjusting  these  values  principally  influences 
the  time  constant  of  the  washouts. 

Figure  5.7  depicts  the  optimization  history  for  this  problem. 
The  top  graph  depicts  the  progress  of  the  controller  margin  with  each  iteration.  The 
second  graph  shows  the  progress  of  the  total  cost  with  each  iteration  The  lower  graph 
depicts  the  progress  of  the  plant  parameters.  Three  optimization  runs  are  shown, 
initialized  at  values  of  Co  =  (10,  10]^,  (0.12,  50]^,  and  (1,  20]^.  The  plots  were 

shifted  horizontally  so  as  to  terminate  at  the  same  iteration  count. 

This  example  has  a  number  of  interesting  features.  First  of  all, 
note  that  the  final  output  value  was  independent  of  the  initialization  conditions. 
While  this  by  no  means  proves  the  existence  of  a  unique  minima  in  the  feasible  set, 
it  is  an  encouraging  result.  Secondly,  unlike  the  single  variable  problem,  which  was 
known  to  be  quasi-convex,  the  controller  margin  does  not  decrease  monotonically  with 
each  iteration.  Finally,  during  the  progress  of  the  optimization,  the  stab  control  power 
actually  falls  below  its  convergence  value.  What  is  significant,  however,  is  that  the 
total  cost  continues  to  decrease  monotonically  as  the  stab  control  power  overshoots  its 
optimal  value  and  then  corrects.  About  a  dozen  permutations  of  this  problem  were  run 
with  various  weighting  vectors  and  differing  performance  specifications.  The  following 
identically  significant  behaviors  were  observed:  1 )  the  output  values  were  always 
independent  of  the  initialization  vector  ^^nd  2)  the  total  cost  always  decreased 
monotonically. 
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Figure  5.7:  Optimization  History  for  Longitudinal  F>14  Problem  with  Mul¬ 
tiple  Initial  Conditions  (Example  Five) 

Another  issue  of  significant  importance  is  actuator  activity.  It 
might  be  expected  that  the  optimization  routines  minimized  control  power  at  the 
expense  of  unacceptable  increases  in  actuator  activity.  This  turned  out  not  to  be  the 
case,  since  actuator  deflection  was  constrained  as  a  part  of  Hra  problem  formulation. 
Figure  5.8  shows  the  broken-loop  control  responses  for  the  stab  and  DLC  actuators. 
With  cross-over  frequencies  in  the  range  of  one  to  three  radfs,  the  actuator  demands 
for  this  problem  are  about  one  order  of  magnitude  less  than  modern  flight  control 
actuator  capacity. 
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Figure  5.8:  Broken-Loop  Control  Response  for  Longitudinal  F-14  Problem 
(Example  Five) 

(2)  A  Lyapunov  Approach 

The  second  approach  using  the  closed-loop  formulation  was  to 
consider  the  closed-loop  transfer  function  from  the  command  reference  signal  to  each 
control  as  an  output,  and  explicitly  limit  the  steady  state  value.  Let  A",  be  the 
row  of  the  state-feedback  gain  matrix  corresponding  to  the  control  input  u,,  and  let 
«.  ;=  “*"**1 .  The  closed-loop  transfer  function  from  w  to  «,•  is: 

=  Ki  {si  -{A  +  BaA'))-’  B,.  (5.46) 


Enforcing 


Tuiw{0)  <  Vi 


yields: 


+ A',(A-|-B2A')-‘B,  >0. 


Note  that  since  Vi  is  scalar,  this  is  equivalent  with  the  expression: 


det  (vi  +  f<i(A  +  >  0. 


(5.47) 


(5.48) 
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and 


Recall  Schur’s  determinantal  formula  [Ref.  41],  that  given;  M  = 
det(F)  5^  0: 

det(A/)  =  det(F) det  (j  -  .  (5.49) 


Consequently, 
det 


Ki  Vi 


=  det  (»/.  +  Ki(A  +  Biiq-^Bx)  det  (-(/I  +  BjK)) 


=  det  ^-(>1  +  B2K)  -  det(»;,) . 

Equation  5.48  is  consequently  equivalent  with: 

det(-M  +  kA-)) 

Note  that  det(»;,)  >  0,  Furthermore,  assume  {A  +  B^K)  is  stable,  which  implies  that 
det  (— (y4  +  B2K))  >  0.  The  constraint  can  now  be  expressed  as: 


det  ^-(/l  +  B2K)  -  >  0.  (5.51) 

Note  that  (^A  +  B2K  +  stable  is  a  sufficient  (but  not  necessary)  condition  for 
satisfaction  of  this  scalar  inequality.  If  we  again  use  the  controller  parameterization 
A'  =  lyV"”*,  this  can  be  expressed  by  Lyapunov’s  equation  as  the  LMI: 

T  XT  BiWi  +  W^BT 

AY  +  YA^  +  B2W  +  W^Bj  +  *  '  '  <  0.  (5.52) 

Vi 


An  example  problem  using  this  formulation  were  not  completed,  however,  the  codes 
supporting  this  approach  are  included  in  Appendix  D. 

b.  Dynamic  Maneuverability  Requirements:  Open-Loop  For¬ 
mulation 

In  this  section  we  propose  a  methodology  for  inclusion  of  open-loop 
maneuverability  constraints  in  a  strictly  open-loop  formulation.  As  discussed  earlier. 
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such  constraints  may  include  maximum  pitch  rate,  roll  rate  or  yaw  rate  requirement 
with  all  the  control  surfaces  set  at  their  maximum  deflections.  It  turns  out  that  these 
constraints  can  be  derived  using  the  open  loop  linear  plant  matrices  such  as  Aaero 
and  Baero  introduced  in  the  previous  section. 

Assume  that  the  scalar  output =  r  is  also  represented  by  one  of  the 
states  of  the  system,  x,-.  With  all  other  states  zero,  the  maximum  steady  state  value 
of  X,  can  be  expressed  by: 

0  =  )  (5.53) 

where  /!(,,,•)  denotes  the  f-th  diagonal  element  of  A,  and  denotes  the  corre¬ 

sponding  row  of  B2>  Note  that  must  be  negative  in  order  to  represent  a  stable 
equilibrium  condition.  The  open-loop  constraint  can  now  be  posed  as  the  inequality: 

+  B2f,.^max  <  0.  (5.54) 

This  is  now  affine  in  our  plant  matrices,  and  the  plant  optimization  constraint  can 
be  posed  as  the  LMI: 

-  •4(i.i)(C)2</ire*  -  B2^,.^{0'^  max  ^  0.  (5.55) 

Note  that  the  assumption  can  be  relaxed  that  z  be  represented  by  a  system  state. 
This  is  because  if  z  =  Cx,  then  a  similarity  transform  S  exists  which  can  make  z  a 
state  X,  of  an  equivalent  system: 

X  =  At  -1-  B2"u  :  z  =  x,.  (5.56) 

Furthermore,  if  A  and  B2  are  affine  in  (,',  then  A(C)  =  SA(OS~^  and  ^2(0  =  SB2{C) 
are  affine  in  C- 

Constraint  5.55  can  therefore  be  po.sed  jointly  with  any  of  the  other 
proposed  constraints,  and  the  plant/controller  optimization  problem  solved  as  before. 
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Because  this  constraint  is  truly  open-loop,  and  only  applies  to  the  plant  optimization 
phase  of  the  routine,  it  can  be  omitted  from  the  constraints  imposed  during  the 
closed-loop  controller  optimization  as  with  constraint  5.29. 

Example  Six-  Optimization  of  Multiple  Surfaces  with  Open  and  Closed-Loop  Perfor¬ 
mance  Requirements 

Let’s  revisit  the  F-14  longitudinal  example.  This  time  consider  the 
additional  open-loop  maneuverability  requirement  that  adequate  control  power  exist 
to  generate  at  least  0.5  rad/sec  of  positive  pitch  rate  with  the  stabilator  deflected  20 
degrees  from  the  trimmed  value,  and  the  DLC  neutral.  Consequently,  stabmax  =  ^ 
radians  and  equation  5.55  now  becomes: 

20 

~  ^oerO|3,3)(C)(0‘2^’fld)  —  5aerO(3,i)(C)gY  J  ^  (5.57) 

This  LMI  was  included  in  the  plant  optimization  phase  of  the  plant/ 
controller  algorithm.  Figure  5.9  depicts  the  progress  of  the  algorithm.  The  addition  of 
this  open-loop  maneuverability  constraint  resulted  in  an  increa.se  in  the  required  size 
of  the  stabilator  from  0.12  to  0.34  of  its  normalized  value.  The  DLC  size  predictably 
remained  the  same  as  in  Example  Six.  The  results  shown  in  Figure  5.9  indicate  that 
the  closed-loop  Hoo  performance  constraint  was  responsible  for  sizing  the  DLC,  while 
the  open-loop  maneuverability  constraint  was  responsible  for  appropriately  sizing  the 
stabilators.  The  abrupt  change  in  the  controller  margin  is  for  the  identical  reason  as 
that  explained  in  Example  Four. 
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Iterations 


Figure  5.9:  Optimization  History  for  F-14  Problem  with  Open-Loop  Con 
straint  (Example  Six) 


Example  Seven-  Optimization  of  Multiple  Surfaces  with  Open  and  Closed-Loop  Per¬ 
formance  Requirements  and  Directed  Thrust 


The  objective  of  this  example  is  to  demonstrate  that  more  uncon¬ 
ventional  control  effectors  can  be  easily  incorporated  into  the  proposed  methodology. 
Therefore,  in  addition  to  the  aerodynamic  control  surfaces,  provision  was  made  in  the 
model  for  the  deflection  of  the  engine  exhaust  to  provide  additional  moment  (directed 
thrust).  In  this  simplified  model  the  thrust  is  set  to  the  trimmed  value  of  13,118  Ibf, 
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and  ancillary  nonlinear  effects  of  thrust  vectoring,  such  as  entrainment,  are  ignored. 
The  commanded  thrust  deflection  is  set  to  be  equal  to  the  stabilator  deflection,  with 
similar  actuation  rates,  such  that  Sthruit  =  ^stab-  Consequently,  the  controls  problem 
remains  a  two-input  problem. 

We  first  discuss  incorporation  of  the  directed  thrust  into  the  synthesis 

model.  Define  the  following  parameters: 

To  :=  trimmed  thrust  value  (Ibf) 
le  :=  engine  lever  arm  (/<) 

0e  '=  thrust  deflection  angle  (rad),  relative  to  body  axis 
Oeo  :=  nominal  installed  thrust  deflection  angle  (rad). 


Using  above  notation  and  the  notation  of  the  previous  section,  the  nonlinear  directed 


thrust  contribution  to  the  state  derivatives  can  be  expressed  as: 


■  U  ■ 

^cos(0^) 

a 

-  Tn 

-;;lySin(0e) 

Q 

—  ■‘0 

-I-JltS\n(0e) 

0 

thrust 

0 

(5.58) 


Linearizing  equation  5.58  about  a  nominal  flight  condition  results  in  the  following 


expression: 


u 

a 

=  To 

thrust 

-^cos(0eo) 

-/■^*/eCOs(0eo) 

0 


(Oe-O.,). 


(5.59) 


Incorporating  directed  thrust  in  the  aircraft  dynamics  results  in  the  new  expression 


for  Baero  defined  in  equation  5.40: 


'aero  — 


R 


-^Tosin(<l,J 

~7^'^ocos(0e„) 

0  ■ 

■ 

■  0 

0  ■ 

• 

0 

Cl...,  T 

1 

0 

-^'^oleCOs(0e^) 

0 

f,fo6 

0 

0 

0 

r 

0 

0  . 

119 


■ 

■  0 

^Ddlc/^Ldlc 

" 

^Ldlc'^ 

0 

1 

0 

0  0 

. 

(5.60) 


Note,  whereeis  Baeroo  had  previously  been  zero,  it  has  now  includes  the  directed  thrust 
contribution. 

The  open-loop  maneuverability  specification  given  by  equation  5.57 
retains  the  same  form.  When  expanded,  this  inequality  is  now: 

- -e„)>o.  (s.ei) 

lyy 

The  expectation  was  that  significantly  less  stabilator  control  power  would  be  required 
due  to  the  ability  of  the  directed  thrust  to  provide  large  moments. 

As  can  be  seen  from  Figure  5.10,  the  methodology  determined  that 
essentially  no  stabilator  control  power  was  required  in  order  to  meet  the  specifications, 
and  a  controller  was  found  which  satisfied  the  requirements  using  directed  thrust  and 
DLC  alone.  Note  that  the  availability  of  the  directed  thrust  did  not  decrease  the 
amount  of  DLC  control  power  necessary  to  meet  the  requirements.  This  was  to  be 
expected  since  the  influences  of  these  two  control  inputs  on  the  plant  dynamics  are 
nearly  orthogonal. 

This  example  demonstrated  that  that  diverse  control  inputs,  such 
as  directed  thrust  can  be  handled  by  the  methodology  we’ve  proposed.  However, 
additional  constraints  will  have  to  be  imposed  to  guarantee  a  satisfactory  solution  for 
night  conditions  where  thrust  setting  is  not  constant,  such  as  terminal  area  flight. 

In  this  section  we  have  shown  that  the  proposed  methodology  can 
easily  accomodate  various  static  and  dynamic  maneuverability  requirements.  In  par¬ 
ticular,  it  was  demonstrated  that  these  requirements  can  be  formulated  as  LMI’s  and 
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Figure  5.10:  Optimization  History  for  F-14  Problem  with  Directed  Thrust 
(Example  Seven) 

included  in  the  plant/controller  optimization  algorithm  together  with  the  closed-loop 
performance  and  stability  constraints. 

F.  ACCOMODATING  MODEL  UNCERTAINTY 

The  hazards  associated  with  under-designing  the  control  power  are  extreme, 
and  yet  the  answers  determined  by  the  methods  above  presume  perfect  knowledge 
of  the  linear  plant.  As  a  consequence,  sound  engineering  practice  would  demand 
that  provision  was  made  in  the  design  process  to  ensure  that  inaccuracies  in  the 
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linear  synthesis  model  would  not  be  responsible  for  the  gross  under-design  of  the 
control  surfaces.  If  one’s  confidence  in  the  aerodynamic  derivatives  was  within  ten 
percent,  then  the  temptation  might  be  to  simply  pad  the  tail  size  by  ten  percent.  This 
methodology  would  fail  to  recognize  that  it  is  the  dynamics  of  the  whole  vehicle  which 
are  uncertain,  and  might  result  in  sub-optimal  allocation  of  the  control  power  to  cope 
with  the  other  uncertainties  in  the  knowledge  of  the  plant.  Because  of  the  small  gain 
theorem  (Theorem  3.7),  the  Hoo  methodology  of  section  C  was  easily  extensible 
to  the  problem  of  providing  robust  control,  and  optimization  of  the  vehicle  control 
power  which  would  guarantee  both  robust  stability  and  fulfillment  of  the  performance 
objectives. 

This  proves  to  be  an  interesting  problem,  because  the  formulation  of  the  syn¬ 
thesis  model  for  plant  optimization  with  a  robust  stability  constraint  is  significantly 
different  from  the  Woo  constraint  posed  above.  Consider  again  the  uncertainty  model 
for  longitudinal  aircraft  dynamics  presented  in  Chapter  IV,  in  which  parametric  un¬ 
certainty  was  modeled  by  uncertainties  on  the  total  lift,  drag  and  moment  gener¬ 
ated  by  purely  aerodynamic  forces.  Figure  4.1  depicted  the  inputs  and  outputs  of 
the  uncertainty  block.  Consider  the  linearization  of  that  nonlinear  plant,  replac¬ 
ing  Fgrav  and  Fdyn  with  Agrav  and  Furthermore,  let  Aaero  represent  that  the 

aerodynamic  influences  such  that  i4aero  introduced  in  equation  5.39  has  been  decom¬ 
posed  into  its  aerodynamic,  gravity  and  dynamic  coupling  contributions,  such  that 
Aaero  ~  Agrav  4"  “b  F-vilyAatro  • 

The  uncertainty  inputs  and  outputs  to  the  linear  system  can  then  be  represented 
as  depicted  in  Figure  5.11.  The  system  depicted  by  Figure  5.11  can  be  posed  in  a 
state-space  representation: 


=  (A 

aero  (C)  +  B2(()K)x  -I-  Ru,bm 

{AaeroiO  +  B2{OI<)x 


(5.62) 
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Figure  5.11:  Linearized  Uncertainty  Model 

By  the  Small  Gain  Theorem,  the  closed-loop  system  will  be  stable  for  all  {A  :  ||A||oc.  < 
if  and  only  if  ||r*,,uJ|oo  <  1-  This  constraint  can  be  expressed  by  the  LMI: 


■  /  AaeroiOY  +  K/l„ro(C)'+  \ 

B,(OW  -h  ) 

{A  aero  iOY  +  B2(0W) 


{A  aero  (C)y'  +  B^iowy 

-I 


<  0. 
(5.63) 


The  problem  is  different  from  those  encountered  previously  in  that  this  single  matrix 
inequality  is  affine  in  both  the  controller  parameters  plant 

parameters  (.  This  LMI  can  consequently  be  used  for  both  phases  of  the  optimization 
procedure. 

Time  precluded  the  completion  of  a  design  example  using  this  formulation, 
though  the  scripts  which  support  this  problem  are  included  in  Appendix  D. 
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G.  GENERAL  COMMENTS 

This  section  presents  several  diverse  comments  on  the  methodology  presented 
above. 

1.  Interpreting  the  Results 

What  does  the  output  of  this  methodology  mean?  Two  mathematical  issues 
are  significant.  First  of  all,  though  each  of  the  two  phases  of  the  method  are  afBne 
problems,  and  despite  considerable  effort,  we  have  been  unable  to  mathematically 
establish  that  the  feasible  set  for  the  joint  controller/  plant  optimization  problem  is 
convex.  Consequently,  absent  a  proof  of  convexity  of  the  feasible  set,  the  existence 
of  lower  cost  solutions  can  not  be  discounted.  Secondly,  a  feasible  solution  to  the 
appropriate  LMI  is  both  necessary  and  sufficient  for  the  existence  of  a  state-feedback 
controller  satisfying  either  the  Hoo  constraint  or  the  pole  placement  specification. 
When  more  than  one  Hoo  constraint  is  jointly  imposed,  or  the  Tioo  constraint 
is  imposed  jointly  with  another  constraint,  such  as  pole  placement,  then  a  feasible 
solution  to  the  joint  LMI  is  clearly  a  sufficient  condition  for  a  feasible  controller, 
k  is  no  longer,  however,  a  necessary  condition  [Ref.  25].  Again,  absent  a  proof  of 
necessity,  controllers  might  exist  which  would  permit  further  reduction  of  J.  The 
output  J  =  c^Copt  is  consequently  an  upper-bound  to  the  optimum  value  of  J. 

2.  The  Example  Problems 

It  is  important  to  mention  that  the  first  several  example  problems  could 
have  been  solved  by  easier  means.  These  examples  were  not  intended  to  suggest 
that  our  methodology  should  be  used  to  solve  these  types  of  problems,  but  rather  to 
demonstrate  the  methodology  on  small  easily  visualized  problems.  The  answers  in  fact 
confirmed  our  intuition  into  these  simple  problems.  The  power  of  the  methodology  is 
its  direct  applicability  to  much  more  complex  problems  with  multiple  variables  and 
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joint  constraints,  for  which  no  other  direct  method  exists. 

3.  Limitations  of  the  Methodology 

It  is  important  to  identify  the  limitations  of  the  methodology.  The  above 
examples  demonstrate  the  viability  of  the  method,  and  its  flexibility  to  simultaneously 
adjust  to  diverse  specifications.  There  were  however  two  assumptions  which  implicitly 
limit  its  application: 

1.  The  linear  model  faithfully  represents  the  dynamic  character  of  the  plant 

2.  The  plant  could  reasonably  be  expressed  as  an  afflne  function  of  the  optimization 
parameters. 

Neither  of  these  assumptions  was  considered  to  be  significantly  limiting,  as  there  are 
a  wide  range  of  examples  for  which  they  are  both  reasonable.  It  is  worth  noting  for 
the  reader  one  example  for  which  an  aircraft  would  not  be  affinely  dependent  upon  a 
control  size.  In  the  case  of  a  closely-coupled  canard,  the  affine  assumption  would  not 
be  reasonable,  as  the  size  of  such  a  canard  can  have  a  dramatic  effect  on  the  influence 
coefficients  of  the  surfaces  located  in  its  wake. 

Furthermore,  there  is  one  other  significant  explicit  limitation —  the  exis¬ 
tence  of  a  feasible  controller.  Several  example  problems  were  attempted  for  which  no 
feasible  controller  could  be  found.  This  was  most  common  when  multiple  joint  spec¬ 
ifications  were  imposed.  The  methodology  cannot  guarantee  a  priori  the  existence 
of  a  controller  in  the  presence  of  conflicting,  or  mutually  incompatible,  performance 
criteria. 

4.  Other  Applications 

The  focus  of  both  the  discussion  and  the  examples  has  been  the  optimiza¬ 
tion  of  control  power,  i.e.  those  items  whose  principal  influence  manifests  itself  in 
the  B  matrix  of  the  state-space  representation.  Furthermore,  the  examples  have  each 
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suggested  that  the  size  of  surfaces  might  be  the  principal  figure  of  interest.  The  ap¬ 
plication  of  the  methodology  is  not,  however,  restricted  to  those  features  of  a  vehicle 
which  represent  control  power.  Any  feature  whose  contribution  to  the  dynamic  system 
can  be  posed  in  an  affine  manner  can  be  included  in  the  vector  of  plant  parameters, 
and  consequently  be  reflected  in  the  cost  function.  Strakes  and  fixed  fins  would  be 
examples  of  features  which  might  only  have  a  contribution  in  the  A  matrix,  but  are 
likewise  perfectly  suited  to  the  application  of  this  method.  Occasionally,  destabilizing 
features  such  as  blisters,  antennas  or  external  stores  must  be  appended  to  a  vehicle. 
The  methodology  can  then  be  applied  to  find  the  maximum  acceptable  size  of  the 
feature  by  including  the  negative  contribution  of  the  feature  in  &nd  finding  the 
minimum  negative  value  of  the  sizing  parameter.  Finally,  recall  that  in  the  example 
problems  that  the  tail  volume  was  defined  as  the  normalized  product  of  the  surface 
area  and  its  distance  from  the  eg.  The  influence  of  a  feature  is  consequently  also  affine 
in  its  position  as  well  as  its  size,  and  so  the  methodology  might  instead  be  applied 
to  optimizing  position  rather  than  size  for  some  applications.  The  method  presented 
in  this  chapter  is  consequently  broadly  applicable  to  a  wide  variety  of  problems  not 
demonstrated  here. 

H.  FUTURE  DIRECTIONS 

The  following  subjects  present  the  foundations  for  future  work. 

1.  Convexity  Issues 

Though  the  value  of  the  above  methodology  does  not  hinge  on  the  problem 
being  proven  to  be  convex,  convexity  remains  an  interesting  subject.  This  is  partic¬ 
ularly  true  if  the  method  is  to  be  expanded  to  other  applications.  One  particularly 
interesting  direction  to  be  pursued  is  the  method’s  close  resemblance  to  D-K  itera¬ 
tion  (Ref.  34].  D-K  iteration  is  a  method  by  which  robust  controllers  are  designed 
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by  iteratively  designing  a  controller  and  then  performing  a  similarity  transform  on 
selected  inputs  and  outputs  to  scale  for  robustness.  Though  the  method  has  been 
recognized  and  used  for  some  time  by  the  controls  community  ,  special  cases  of  the 
problem  were  just  recently  proven  to  be  convex  [Ref.  42,  43].  The  similarity  of  these 
two  problems  tenders  some  hope  that  the  problem  we’ve  posed  may  yet  prove  to  be 
convex. 

In  the  event  that  general  convexity  can  not  be  demonstrated,  perhaps  the 
mathematical  nature  of  the  problem  can  further  be  refined  to  enhance  our  understand¬ 
ing  of  the  result.  Can  a  lower  bound  be  computed?  Is  the  result  a  local  or  global 
minimum?  Are  there  other  special  conditions  for  which  convexity  of  the  problem  can 
be  assured  or  imposed?  For  example,  if  one  could  determine  the  smallest  convex  set 
which  contained  tlie  feasible  .set,  then  a  lower  bound  could  be  found  by  minimizing 
the  cost  function  over  that  convex  set.  A  lower  bound  close  to  the  upper-bound  found 
through  our  iterative  methodology  would  be  of  tremendous  practical  value.  These  are 
subjects  which  each  warrant  further  investigation. 

2.  Other  Convex  Performance  Constraints 

A  second  limitation  to  the  above  approach  was  its  restriction  to  those  con¬ 
vex  constraints  for  which  an  LMI  formulation  exists.  A  number  traditional  perfor¬ 
mance  metrics  are  convex  problems  for  which  an  LMI  formulation  does  not  presently 
exist  [Ref.  13],  including  overshoot,  rise-time,  settling  time,  and  response  bandwidth. 
The  above  methodology  can  and  should  be  expanded  to  include  these  types  of  per¬ 
formance  specifications. 

I.  CONCLUSIONS 

While  establishing  the  minimum  control  power  requirements  for  a  aircraft  has 
always  been  a  concern,  it  is  now  a  core  design  constraint  with  the  advent  of  aircraft 
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whose  open-loop  dynamics  may  be  unstable.  With  an  unstable  platform,  the  control 
effectors  must  now  not  only  provide  the  capacity  for  adequate  maneuverability,  but 
also  provide  stabilization  and  disturbance  rejection.  For  this  type  of  vehicle,  if  an 
control  actuator  encounters  a  deflection  or  deflection  rate  limit  in  providing  maneu¬ 
verability,  it  reverts  to  its  natural  dynamics  in  response  to  any  disturbance.  Missteps 
in  this  arena  have  been  well  documented.  The  loss  of  the  prototype  Grippen  on  its 
sixth  flight  was  attributed  to  saturated  control  rates  in  an  environment  where  linear 
aero  and  flight  dynamics  prevails  [Ref.  44].  To  under-design  the  control  power  is  to 
court  disaster.  To  compensate  for  the  hazards  by  over  designing  the  control  power  is 
to  forfeit  all  the  benefits  offered  by  reduced  static  stability  (low  monetary  cost,  high 
maneuverability,  low  drag,  low  signature,  low  weight). 

Direct  numerical  methods  have  been  needed  in  which  performance  requirements, 
including  actuator  rates  and  deflections,  are  the  inputs  to  a  methodology  which  then 
can  simultaneously  determine  both  the  lowest  Vost"  configuration  and  its  accom¬ 
panying  controller.  This  chapter  demonstrated  that  many  common  flying  qualities 
specifications  can  be  posed  as  Linear  Matrix  Inequalities.  These  included  stabilization 
requirements,  disturbance  rejection  requirements,  and  static  and  dynamic  maneuver¬ 
ability  requirements.  Furthermore,  a  iterative  method  of  optimizing  a  plant  config¬ 
uration  was  demonstrated  when  the  performance  constraints  can  be  posed  as  Linear 
Matrix  Inequalities.  This  work  is  at  a  threshold,  having  demonstrated  a  viable  means 
for  solving  a  significant  subset  of  control  power  problems,  and  suggesting  an  approach 
to  pursue  the  larger  set  of  convex  performance  constraints,  which  predominate  the 
flying  qualities  specifications. 
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J.  RECOMMENDATIONS 


It  is  recommended  that  the  following  steps  be  taken  to  further  the  contribution 
of  this  work: 

1.  Procure  commercial  interior  point  codes  when  they  become  available.  The  point 
here  is  to  separate  the  influence  of  the  numerical  methods  from  the  application 
of  the  engineering  formulation.  The  coding  of  the  interior  point  algorithm  in 
Appendix  B  restricts  the  engineering  application  of  the  above  formulation  in  two 
ways:  ( 1 )  it  is  slow  due  to  the  choice  of  M  ATLAB  as  the  programming  language, 
and  (2)  the  code  demonstrated  some  irregularities,  such  that  there  were  some 
problem  geometries  for  which  the  path  of  centers  wa.s  unstable.  Consequently 
some  interesting  feasible  example  problems  were  attempted  which  the  available 
interior  point  code  would  not  solve. 

2.  Extend  the  general  methodology  to  other  performance  measures  which  have 
convex  solutions,  but  which  do  not  currently  have  LMI  formulations.  Many 
other  relevant  convex  constraints  exist,  such  as  command  and  controller  band- 
widths,  which  could  also  be  applied  if  the  method  were  extended  to  non-LMI 
formulations. 

3.  Continue  to  pursue  attempts  to  either  prove  convexity  or  find  associated  convex 
problems  which  could  be  used  to  determine  a  lower  bound. 
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VI.  CONCLUSIONS  AND 
RECOMMENDATIONS 


This  report  has  treated  the  subject  of  the  application  of  Hoc  control  design 
and  convex  optimization  to  the  design  of  air  vehicles  and  their  control  systems.  Three 
project  areas  defined  the  scope  of  the  research  effort: 

•  An  Hoo  controller  design  for  the  F-14  autoland  problem,  implementing  Direct 
Lift  as  an  active  control  surface. 

•  The  programming  of  mixed  /  'Hoo  design  tools,  and  their  application  to  the 
autoland  controller  design  problem. 

•  The  formulation  of  the  plant/controller  optimization  problem  in  a  format  where 
an  upper-bound  can  be  determined  by  convex  methods. 

Each  of  these  efforts  were  successfully  completed,  each  with  their  own  sets  of  conclu¬ 
sions. 


A.  Hoo  DESIGN  EXAMPLE  CONCLUSIONS  AND  RECOMMENDA¬ 
TIONS 

The  Hoo  output-feedback  synthesis  methods  were  used  to  determine  an  au¬ 
toland  controller  for  a  carrier- ba.sed  F-14  aircraft.  Significant  results  of  this  efforts 
were: 

1.  A  methodology  was  demonstrated  for  the  formulation  of  robustness  analysis 
models  for  aeronautical  applications.  This  methodology  is  appropriate  for  those 
problems  in  which  the  origin  of  the  parameteric  data  is  flight  test  rather  than 
wind  tunnels. 
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2.  Direct  Lift  Control  was  successfully  implemented  in  a  MIMO  design  for  the 
autoland  problem. 

3.  A  methodology  was  demonstrated  whereby  SISO  design  specifications  were 
translated  in  scalar  weighting  functions  on  the  inputs  and  outputs  of  the  syn¬ 
thesis  model.  This  included  tuning  the  controller  for  specified  bandwidths  of 
the  measurement  sensors. 

4.  A  controller  was  designed  which  did  not  cancel  the  open-loop  poles  of  the  plant. 

5.  The  controller  performance  was  validated  by  nonlinear  simulation. 

This  design  example  extended  the  methodology  of  previous  work  to  the  full  mea¬ 
surement  feedback  problem.  The  methodology  is  recommended  for  consideration 
whenever  Hoo  control  design  methods  are  considered  for  use.  Its  principal  attribute 
is  that  it  represents  a  methodology  by  which  a  controls  designer  with  limited  back¬ 
ground  in  the  theoretical  aspects  of  “Hoo  control  can  still  apply  the  design  tools  with 
confidence. 

B.  MIXED  n2  /  Woo  CONTROL  CONCLUSIONS  AND  RECOMMEN¬ 
DATIONS 

The  mixed  Wj  /  Woo  control  phase  of  the  research  included  both  the  coding  of 
the  necessary  design  tools  for  both  the  continuous  and  discrete  time  problems,  as  well 
as  their  application  to  a  design  problem  similar  to  the  F-14  autoland  problem  above. 
Siginifcant  results  included; 

1.  Design  tools  were  created  which  solve  the  continuous  and  discrete  time  mixed 
W2  /  Woo  controller  synthesis  problems  using  elliptical  convex  optimization 
methods. 
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2.  The  F-14  autoland  control  problem  was  used  to  demonstrate  a  methodology 
whereby  the  continuous  H2  /  Woo  control  design  tools  could  be  used  in  a  MIMO 
controller  synthesis  problem. 

Due  to  the  computational  time  required  to  use  the  mixed  tools,  it  is  recommended  that 
they  only  be  applied  for  design  problems  in  which  an  W2  specification  was  explicitly 
part  of  the  design  requirements. 

C.  PLANT/CONTROLLER  OPTIMIZATION  CONCLUSIONS  AND  REC¬ 
OMMENDATIONS 

Chapter  V  was  devoted  to  outlining  and  demonstrating  a  methodology  whereby 
the  optimization  of  a  vehicle’s  physical  configuration  could  be  posed  for  solution  by 
the  methods  of  convex  analysis.  Specifically: 

1.  It  was  demonstrated  that  many  typical  flying  qualities  requirements  can  be 
jointly  posed  as  Linear  Matrix  Inequalities,  including; 

•  Stabilization  requirements,  including  pole  placement, 

•  Disturbance  Rejection, 

•  Static  and  Dynamic  Maneuverability  (Open-loop)  Requirements. 

2.  It  was  demonstrated  that  plant  dynamics  are  frequently  affinely  dependent  on 
some  physical  attributes  of  the  physical  configuration,  such  as  surface  size. 

3.  A  methodology  was  presented  for  determining  an  upper-bound  to  the  plant/controller 
optimization  problem.  The  method  is  appropriate  for  problems  in  which  the 
design  specifications  can  be  posed  as  Linear  Matrix  Inequalities  and  the  plant 
dynamics  are  affinely  dependent  upon  plant  parameters.  This  problem  was 
shown  to  be  quasi-convex  for  the  optimization  of  single  plant  parameters.  It 
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was  also  shown  how  the  method  results  in  the  determination  of  an  upper-bound 
for  the  cost  functions  for  multiple  parameter  problems. 

4.  A  methodology  was  outlined  for  accommodating  modeling  uncertainties  into 
the  plant/controller  optimization  problem  . 

5.  Multiple  design  examples  were  presented  whereby  joint  performance  require¬ 
ments  were  applied  to  the  prolilem  of  optimizing  aircraft  control  surface  config¬ 
urations. 

This  represents  the  principal  major  contribution  of  this  research  effort.  It  is  recom¬ 
mended  that  the  following  items  be  pursued  in  this  area: 

1.  Commercial  interior  point  codes  should  be  procured  when  they  become  avail¬ 
able. 

2.  The  general  methodology  should  be  extended  to  other  performance  measures 
which  have  convex  solutions,  but  which  do  not  currently  have  LMI  formulations. 

3.  The  issue  of  convexity  should  continue  to  be  explored,  including  attempts  to 
identify  bounding  convex  sets. 
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APPENDIX  AiALGORITHMS  FOR  THE 
SOLUTION  OF  THE  MIXED  H2  /  Hoo 
CONTROLLER  SYNTHESIS  PROBLEMS 

This  appendix  presents  the  numerical  tools  which  were  coded  to  solve  the  mixed 
^2  /  Woo  control  synthesis  problem.  It  includes  both  the  mathematical  derivations  of 
various  terms,  as  well  as  verbatim  listings  of  the  hnal  codes.  Since  no  numerical  codes 
were  available  to  solve  these  problems,  a  considerable  amount  of  time  was  devoted 
to  the  design  of  the  necessary  numerical  routines.  The  optimization  problems  in  this 
appendix  were  all  solved  by  the  ellipsoidal  method. 

First,  .section  A  presents  several  simple,  but  perhaps  obscure,  relationships 
which  were  critical  to  the  derivation  of  analytical  expressions  for  the  gradients  of 
the  various  matrix  functionals.  Next,  section  B  presents  the  codes  associated  with 
the  continuous  time  W2  /  Woo  problem.  Section  C  then  presents  the  codes  associated 
with  the  discrete  time  mixed  Wj  /  Woo  synthesis  problem.  Finally,  section  D  presents 
a  short  discussion  of  the  validation  of  the  codes. 

A.  FINDING  THE  GRADIENTS  OF  MATRIX  FUNCTIONALS 

Both  the  continuous  and  discrete  W2  /  Woo  state-feedback  problems  can  be 
numerically  solved  by  the  straightforward  application  of  the  ellipsoidal  convex  op¬ 
timization  algorithm,  described  in  Chapter  II.  In  both  cases,  the  most  challenging 
part  was  the  derivation  and  coding  of  analytical  expressions  for  the  subgradients 
of  non-differentiable  functions.  The  following  relationships  are  instrumental  in  the 
derivations  of  the  subgradients  that  follow. 
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1.  Derivative  of  an  Eigenvalue  of  a  Symmetric  Matrix  I\inctional 
Since  most  of  the  constraint  functionals  (and  some  objective  functionals) 
are  of  the  form  Q{x)  <  0,  it  is  necessary  to  be  able  to  determine  the  gradient  of 
<f>{x)  :=  A,„ai(Q(x)).  From  [Ref.  45],  given  a  symmetric  matrix  functional  Q{x)  = 
Q(x)^  €R"^"  operating  on  x  €R',  and  the  scalar  function  ^(x)  :=  A,„ai(Q(i'));  the 
gradient  of  ^(x)  is  g,  such  that  for  each  element  of  g: 


^  d^(x)  _  for  all  i  = 


dx 


dxi 


(A.l) 


where  u(x)  is  the  eigenvector  associated  with  the  maximum  eigenvalue  of  Q(x),  and 
n*(x)  is  its  conjugate  transpose. 

2.  Derivative  of  a  Matrix  Inverse 

Matrix  inverses  occur  frequently  in  various  Riccati  equations.  An  expres¬ 
sion  for  their  derivatives  is  consequently  required.  From  [Ref.  46): 


d(A'-’ A')  =  d(I)  =  0  =  d(A'-'  )X  +  A'-'dA', 


hence, 


d(A-‘)  =  -.V-'dAA'-’ 


B.  CONTINUOUS  TIME  MIXED  H2  /  CONTROLLER  DESIGN 
As  discussed  in  Chapter  III  and  [Ref.  11],  the  continuous  mixed  output-feedback 
control  problem  is  based  upon  a  convex  expression  of  the  state-feedback  problem.  It 
can  be  solved  by  the  solution  of  the  filtering  Riccati  equation,  and  the  construction 
of  an  auxiliary  plant  for  which  a  state- feedback  controller  is  designed.  This  section 
consequently  develops  and  lists  the  state-feedback  controller  design  tools  which  can 
either  be  used  independently  or  called  by  the  output-feedback  synthesis  function.  The 
measurement-feedback  controlles  synthesis  tools  then  follow. 


1.  Numerical  Solution  of  the  Continuous  Time  State*Feedback  Prob¬ 
lem 

The  generalized  mixed  continuous  H2  /  Hoo  state-feedback  problem  is 
posed  above  in  Theorem  3.4  as: 

Minimize: 

fi{M{W,Y))  :=  U{(W Do2W)Y-HCoY D^Wf),  (A.2) 
Subject  to:  K  >  0,  and  R(W,Y)  <  0, 

where 

R{W,  Y)  :=  AY  +  YA^  +  -|-  IV^B^  +  B,Bf  -b  (CiK  +  D,2W){C^Y  +  Di2Wf, 

(A.3) 

and  /i  is  the  trace,  /j  is  the  maximum  eigenvalue,  or  /a  is  the  maximum  diagonal 
element.  The  Hoc  constraint  is  assumed  to  be  7  <  1,  and  w  and  z  are  assumed  to 
have  been  scaled  in  order  that  the  constraint  ||  T^w  ||oo<  1  is  feasible.  The  codes 
which  follow  also  required  that  w  and  z  have  been  appropriately  scaled. 

For  the  state-feedback  problem,  the  controller  is  a  constant  gain  matrix  K 
which  has  been  parameterized  as  I\  =  WY~^.  Since  Y  =  Y^  €  R"**"  is  symmetric, 
the  problem  is  a  search  over  the  vector  space  R*,  where  s  =  +nq.  For  simplicity 
and  reduced  computational  expense,  Y  and  W  were  chosen  to  be  affine  functions  of  x: 
Y  =  XiYi,  and  W  =  JT**!  iiWi.  The  easiest  possible  mapping  from  x  — >  (kF,  K) 
was  to  assign  each  x,-  to  a  single  location  (or  pair  of  locations  in  the  case  of  the  off- 
diagonal  elements  of  Y).  The  basis  matrices  and  VF,  therefore  orthonormal  with 
a  single  unit  one  (or  pair  of  ones).  For  t  =  1  to  n,  Yi  had  a  single  unit  value  in  the 
corresponding  diagonal  position,  and  Wi  =  0.  For  i  =  n  -f  1  to  each  Yi  had  a 

pair  of  symmetrical  ones  placed  by  counting  down  each  sub-diagonal,  from  the  first 
sub-diagonal  out  to  the  corners.  For  i  =  to  +  nq  ,  each  VF,  was  all  zero 
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with  the  exception  of  a  single  one,  counting  down  the  columns  from  left  to  right.  For 
this  range  Vi  =  0.  This  structure  is  significant  in  that  when  Yi  and  Wi  show  up  in  the 
gradient  expressions,  the  multiplication  was  not  required,  but  the  appropriate  row(s) 
or  column(s)  simply  selected  out. 

An  ellipsoidal  algorithm  was  coded  in  MATLAB  following  the  method  of 
Chapter  II  and  using  the  following  structure: 

1.  Determine  if  the  'Hoo  problem  is  feasible,  and  determine  a  particular  feasible 
controller  Kp.  This  was  done  by  solving  the  synthesis  equation  using  the 
Riccati  solvers  in  the  /t-tools  toolbox  (Ref.  24]. 

2.  Determine  an  initial  feasible  solution  Vp  and  Wp  =  A'pVp  from  a  solution  to  the 
Hoo  analysis  equation  (3.2). 

3.  Initialize  the  search  at  x  =  (0, . . . ,  0]^,  with  a  very  large  ellipsoid  about  x. 

4.  From  x,  determine  and  W  as  perturbations  of  the  particular  solution  ( Wp,  i  p). 

5.  Evaluate  the  constraint  ^i(x)  =  F)  <  0.  If  ^i(x)  >  0,  then  use  the 

eigenvector  associated  with  the  maximum  eigenvalue  to  calculate  the  subgradi¬ 
ent:  g\  =  Update  the  ellipsoid  and  x  and  return  to  step  4. 

6.  Evaluate  the  constraint  <t>-i(x)  —  Amoi(A(VF,  >'))  <  0.  If  (^2(2^)  >  0,  then  use  the 

eigenvector  associated  with  the  maximum  eigenvalue  to  calculate  the  subgradi¬ 
ent:  g2  =  Update  the  ellipsoid  and  x  and  return  to  step  4. 

7.  With  both  constraint  functionals  satisfied,  evaluate  the  objective  function  il?(x)  = 
f{M{W,Y))  and  its  subgradient;  gs  =  Update  the  ellipsoid,  i,  and  the 
upper  and  lower  bounds  on  the  estimate  of  the  optimum  cost. 

8.  Return  to  step  4  unless  the  termination  criteria  is  satisfied. 
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9.  Calculate  the  (8ub)optimal  controller  K  =  WY~^. 

10.  Exit. 

Two  significant  computational  issues  were  involved  in  actually  coding  the 
above  routine:  1)  how  to  test  for  positive  definiteness;  and  2)  how  to  calculate  the 
maximum  eigenvalue  and  its  corresponding  eigenvector  (both  for  the  subgradients 
and  the  /}  generalized  cost).  The  first  was  important  because  both  of  the  above 
constraint  functions  required  a  true/false  assessment  of  the  negative  definiteness  of 
—Y  and  R.  Two  methods  were  considered:  Cholesky  factorization,  and  the  compu¬ 
tation  of  the  maximum  eigenvalue.  If  a  Cholesky  factorization  of  Y  or  —R  could  be 
computed,  then  that  expression  was  positive  definite,  and  the  procedure  could  move 
on  to  the  next  step.  If  the  factorization  failed,  then  the  maximum  eigenvalue  and 
its  corresponding  eigenvector  would  have  to  be  calculated  for  the  subgradient  calcu¬ 
lation.  The  advantage  of  a  Cholesky  test,  is  that  it  is  a  very  efficient  calculation, 
which,  if  successful,  would  avoid  the  comparatively  expensive  eigen-problem  for  that 
step.  As  for  the  determination  of  the  maximum  eigenvalue,  two  choices  were  appar¬ 
ent.  Clearly  one  choice  would  be  to  invoke  MATLAB’s  eig  function  and  solve  the 
whole  eigen-problem.  The  second  choice  would  be  to  use  inverse  iteration  to  isolate 
just  the  maximum  eigenvalue  and  it’s  vector.  The  aig  function  was  chosen  because 
the  MATLAB  implementation  is  native  to  the  MATLAB  core  program,  and  takes 
advantage  of  symmetry  for  problems  such  as  this.  It  was  consequently  faster  to  do 
the  entire  eigen-problem  by  eig  than  run  a  line-compiled  subroutine,  though  the  later 
required  fev’er  Hops.  Similar  results  were  encountered  in  choosing  a  method  for  the 
definiteness  test.  Though  a  version  of  h2inf8yn  successfully  ran  using  a  Cholesky 
test,  it  was  no  faster  than  the  eigen  test  because  of  aig’s  implementation  directly  in 
MATLAB.  Furthermore,  the  Cholesky  dependent  variant  was  not  as  reliable  when 
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large  problems  were  run.  Consequently,  the  reader  will  note  that  eig  was  chosen  in 
resolving  both  issues.  These  choices  should  be  reevaluated  in  the  event  that  these 
codes  are  translated  into  either  FORTRAN  or  ‘C’. 


The  gradient  expressions  are  derived  below  for  the  each  of  the  e  =  1  to  n 

elements: 

_  d<f>x{x) 
dxi 

,dY 

=  — 1i  — u 

dXi 

=  —u*YiU 

=  -tr(y^uu*).  (A.4) 

d<i)2{x) 

S2,  =  — a — 

axi 

axi 

=  vr-~  {AY^YA^  ■\-B2W 

(CxY  +  Dx2W){CxY  +  Dx2Wf]  « 

=  u  [AYi-^YiA^  A-  B2 Wi  +  Bj + 

(CxYi  +  Dx2W,){CxY  +  Dx2W)^  +  (CxY  +  Dx2W)(CxYi  +  Dx2Wif}  u 

=  tr  {{AYi  A  YiA'^  A  B2Wi  +  WlBj A 

{CxYi  A  Dx2Wi){CxY  A  Dx2Wf  A  (CxY  A  Dx2W){CxYi  +  uu') 

=  2  tr  ({(CiT  +  DiiWfnu^Cx  +  uuA}  V;)  + 

2  tr  ({(CiT  +  Di2Wfuu*Di2  A  .  (A.5) 


The  arrangement  of  these  expre.ssions  is  not  unique,  but  has  been  chosen 
deliberately  to  place  the  basis  matrices  Wi  and  Yi  on  the  outside  of  the  argumem  of 
the  trace.  The  nature  of  the  basis  matrices  Wi  and  Yi  being  all  zero  except  a  single  one 


or  pair  of  one's,  meant  that  neither  the  evaluation  of  the  trace  nor  the  multiplication 
by  Wi  or  Yi  was  required,  but  simply  the  selection  of  a  single  appropriate  element  out 
of  the  central  expression. 


In  the  case  of  the  objective  function,  the  gradient  will  first  be  derived  for 
fi  (max  eigenvalue). 

d^(x)  dfiiMjW^Y))  dX^„AMiW,Y)) 

dxi  dxi  dxi 

,dM{W,Y) 

=  u  - - - u 

OXi 

=  U*^  {{CoY  +  Do2W)Y-^{CoY  +  DoiW)'^}  u 

=  u*{{CoYi-\-Do2Wi)Y-^(Cf,Y  +  Do2Wf 

+(CoY  +  Do2W)Y-HCoY,  +  DoiWif 
-{CoY  +  Do2W)Y-'YiY-'{CoY  +  Do2\Vf+}  u 

=  tr{(r-'(CoK  +  Do2WfxYuCo  +  C^u'u{CoY  +  Do2W)Y-^)  Yi} 
-tr{y"‘(Coy'  +  Do2WftYu{CoY  +  Do2W)Y-^\'i} 

+tr  {y'-'(Cor  +  Do2WfuUiDo2Wi  +  WT Dlyu(CoY  +  Do2W)Y-^} . 

(A.6) 

The  gradients  of  fi{M{W,Y))  and  f3(M(W,Y))  are  then  minor  modifica¬ 
tions  [Ref.  29].  For  /i,  replace  u*«  with  the  identity  matrix  /.  For  /a,  replace  u  with 
the  elemental  vector  e,'  =  [0, . . . ,  0, 1 , 0, . . . ,  0]^,  where  the  unit  digit  corresponds  with 
the  position  of  the  maximum  diagonal  element. 

2.  Continuous  Time  H2  /  State>Feedback  Synthesis  Codes 

This  section  lists  the  continuous  mixed  H2  /  Hoc.  state-feedback  controller 
design  codes.  The  function  h2infsyn  is  the  principal  script.  The  function 
h2inf forme  is  an  administrative  script  that  maps  x  into  W  and  Y.  Finally,  the  func¬ 
tions  subgradlc,  8ubgrad2c,  and  costgradlc  calculate  the  subgradient  vectors  for 
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the  two  constraint  functionals  and  the  cost  function.  The  coding  of  the  subgradients 
was  validated  by  comparison  with  gradient  vectors  which  were  determined  by  brute 
force  perturbation  methods  (i.e.  gi  =  Zl£±£i|l::/i£l ,  where  e;  =  [0, . . . ,  0, 1,0, . . .  ,0]^). 
h2infsyn 


function  CK,Kp,X,E, count, Pail,Psi2,outcoM,tiii«]s. . . 

h2infByn(f  ,p,DiB,Sf  .■itr,«xit,Xi,Ei,counti,Paili,Pai2i) 

*/.  function  [K, Kp,X,E, count, Pail, Psi2, outcoBo, tiB*]s. . . 

*/.  h2infa]rn(f  ,p,DiB,Sf  ,Bitr,azit,Xi,Ei,counti,Psili,Pai2i) 

•/. 

*/•  Finda  atata-faadback  gmina  for  (aub)optiBal  aizad  b2/hinf  control. 

*/.  Solvaa  for  appropriate  fi  gaina  with  which  to  build  output  faadback 
*/.  controller  if  input  p  ia  auxiliary  plant. 

'/.  Method  of  evaluating  generalized  aixed  h2/hinf  coat  function  can  be  aelected: 
*/.  f«l(trace),  2(Bax  eigenvalue),  or  3(Bax  diag  eleaent) 

V.  System  Batrix  'p*  Bust  be  a  packed  Bu-tools  syatea  matrix: 

•/. 

*/.  DiB(l)  DiB(3)  Dim(2) 

'/.  p  »  I  AA  I  B1  B2  I 

y.  I  CO  I  DOl  D02  I 

y.  I  Cl  I  011  012  I  0iB(4) 

y, 

y.  the  coluama  and  rows  associated  with  the  input  w  and  the  output  zl 
y.  Bust  have  been  scaled  for  gaaima«i 

y.  mitr-  max  number  of  iterations 

y.  exit-  termination  threshold  for  aixed  cost,  expressed  as  a  percentage 
the  other  inputs  are  for  restart  and  the  code  should  be  consulted 

y. 

y.  Outputs : 

y,  K-  dynamic  output  feedback  controller  in  packed  au-tools  format 

y.  Kp-  central  controller  from  Riccati  methods 

y.  count-  Returns  number  of  iterations  for  each  path 

y.  Psil-  Upper  bound  on  mixed  cost 

y.  Psi2-  Lower  bound  on  mixed  cost 

y.  outcome-  textual  result 

y.  time-  elapsed  CPU  time 

timeseputiae; 

outcomes 'max  iterat’; 

y.  unpack  system  matrices 
[AA,B,C,D] *unpck(p): 

nstates>Dim(l) ;  pdiBtsDia(3) ;  routputsDia(4) ;  sdofsDia(5); 

ttsrou(C);  pqsDia(2)-*^pdist; 

BlsB(:  ,l:pdist);  B2sB(:  ,pdiBt-*-l:pq); 

C0=C(1: (tt-routput), :):  Cl»C((tt-routput*l) :tt , :) ; 

001*0(1:  (tt-routput),l:pdist) ; 
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D1 1>D(  (tt-routput't’l) :  tt ,  1  :pdist ) ; 

002>D(1 :  (tt-rontpat)  .pdist^l  :pq) ; 
D12>D((tt-rotttput'»'l)  :tt  .pdist-f  1  :pq) : 

X  prtcoaput*  to  savo  flops 


X  Dstsraino  loasibilitj/coatral  eontrollor 
hui*[AA.  ((B1*B1‘/0.B98)-B2*((D12‘*D12)\B2*)):  -C1**C1,  -AAO; 
Czl,x2,fail]Brie.seltr(hsa):  Xlnf>x2/xl: 

if  (fail>0) 

dispCStatofoodback  linf  problsa  infoasiblo') . 

outcoasB  •  IIFEASIBLE' ; 

rsturn 

•Isslf  alnColgdlnf ))<>0, 

dispC'Hlnf  problM  laf oasiblo  * ) . 

outcoBSB • IIFEASZBLB' ; 

roturn 

ond 

XpB-(D12**D12)\B2**Zinf :  X  eontral  eontrollor 


X  Dotomino  spoeific  soln  froa  control  eontrollor 
nlBAA‘»B2*Kp;  bl>CBl,10000*sqrt(ops)*oyo(nototos)] ;  elBCl'«-012oKp: 
Cxi  ,x2.  foil]  Brie.sehrC  Col '  .el  '*el  :>blobl '  .-ol] ) ;  Yp«x2/xl ; 

if  (foil>0), 

out  conoB  *  ZIDEFZIITE  * :  rotum 
olsoif  (Bin(oig(Yp))<BO), 

outconoB '  ZWOEFZIZTB* ;  rotum 

olso. 

dispC'Stoto  foodbock  hinf  problon  foooiblo*). 

ond 

WpBKpoYp; 


X  Znitiolizo  problon  or  uso  lost  voluo? 


count* Co  0  0] ; 
X*zoros(sdof ,1): 
if  norgin>8, 
countBcounti; 
XBXi: 

ond 


PsilBinf;  Psi2«0; 
EBlOOOBoyoCsdof ) ; 

PsilBPsili;  Pti2BPsi2i; 
iBgi; 


X  bogin  ollipsoidol  soorch  routino 
for  kBirnitr. 

CV.Y]Bh2infforBe(X,Hp.Yp,DiB);  X  nops  X  to  (V.Y) 
CVy,Ey]Boig(-Y); 

CPbil ,  indoxl]  BBox(diog(Ey ) ) ; 

X  Enforco  Y>0 
if  Phil>B0, 

gBsubgrodlc(Vy( ; ,  indoxl )  .nstotos ,  sdof ) ; 

gAgBsqrt(g'*Eg):  EgBEg/gAg; 
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if  Phil>gAg. 

otttcom«« ’ Indcf init*  * ;  return 
•nd 

alpha«Phil/gAg;  count«count‘i-[l  0  0]; 

%  Enforce  hinf  constraint 

else, 

L1»C1*Y+D12*W; 

a«AA*Y4B2*V; 

[Vinf,Einf]«eig(a>a'^BlBl+(Ll’eLl)); 

CPhl2 ,  index]  ■Biax(diag(Einf )) ; 
if  Phi2»0, 

g«subgrad2c(V,Y.Vinf(:. index), Din. AA.B2, Cl, D12,L1); 

Eg»E*g:  gAg«sqrt(g'*Eg):  Eg>Eg/gAg; 

if  Phi2>gAg, 

outcone*  * infeasible  * ;  return 
end 

alpha«Phi2/gAg;  count^count't’CO  1  0]; 

y.  Given  the  above  constraints  satisfied,  folios  cost  gradient 

else, 

CPs  i .  g]  «costgradc  (f .  W .  Y .  CO ,  D02 .  Sf .  Din) : 

Eg*E*g;  gAg>sqrt(g'«Eg):  Eg>Eg/gAg; 

Psi2«nax(  C(Psi-gAg)  jPsi2] )  ; 
if  Psi<Psil. 

Psil>Psi:  alpha«0: 

else, 

alpha>(Psi-Psil)/gAg; 

end 

count>count*CO  0  1]; 

*/•  Exit  criteria 
if  gAg<exit*Psil, 

dispCProgran  converged  to  solution') 
outcone*  *  converged  I ' ; 
break, 
and 
end 

end 

X«X-Ege  (  ( I't’Sdof  *alpha)/(sdof  4-1 ) ) ; 

E»E-2*Eg*  (Eg '  *  (  ( l-t'sdof '*alpha)/(sdof  4' 1 )/( l+alpha)  ) ) ; 
E=E*((l-alpha‘2)*sdof“2/(sdof‘2-l)); 

E=(E4-E’)/2: 


t ineseput ine-t ine ; 
if  outconeBs > converged! ’ , 
K»W/Y: 


y.  Following  are  called  non-organic  functions: 
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X  function  [W,Y,X2]Bh2inffonie(X,Wp,Yp,DiB) 

Y.  function  gl>iubgradlc(Yl,nftntts,idof ) 

Y.  function  g2>subgrnd2c(H,Y,v2,DiB.AA.B2,Cl.Di2) 

Yi  function  [Pii,g]Bcostgradc(f .VtY,C0,D02,Sf .Din) 

Y.  function  out«pck(«,b,c,d)  fron  nu-tools 
Y>  function  (n,b,c,d)>unpck(p)  froa  au-tooln 

Yi  ond  h2infa7n 

\'(v«rb&tia} 

\na 

\nid  \undorlin«{h2inffoxac> 

\ft 

\b«gin{v«rbat ia> 

function  [W,Y]Bh2infforac(X,Vp,Yp,Dia) 

%  roforanta  tho  spnco  X  in  Ra  to  tha  t«o  antricaa 

Yi  X  ia  naauaad  to  ba  coapriaad  of  tha  diagonal  rova  of  Y,  atarting  with  tha 
Yi  aain  diagonal,  followad  by  W  in  coluan  ordar 

natataa*Dia(l) ;  qcontrola0ia(2) ;  pdiat>Dia(3) ;  adof>Dia(6); 

j«natataa; 

Y^YptdiagCX ( 1 : natataa ) ) : 
for  kBl:natataa-l, 
i«natataa-k: 

Y«Y+diag(X(  j+1 :  j+i)  ,k)+diag(X(  j+1 :  j+i)  ,-k) ; 

and 

W*Vp-»’raabapa(X(  j-fl :  j-t’natataaaqcontrol)  .qcontrol.natataa) ; 

Yi  and  h2infforac 


subgrad Ic 

function  glssubgradlc(Y,nitataa,adof ) 

Yi  calculataa  aubgradiant  for  firat  conatraint  function  Y>0 

glBzaroa(adof ,1); 
k*i: 

for  islrnatataa  Yi  counta  out  diag  rowa 

for  jBl:natataa-t-l-*i  Yi  counta  down  diag  rowa 

if  i»*l, 

gl(k)— T(j)av(j)j 
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gl(k)»-2*v(j)*v(j+i-l); 

•nd 

end 

end 

'/.  end  eubgrndlc 


subgrad2c 

function  g2«eubgrnd2c(V,Y,v2,Dia,AA,B2,Cl,D12,Ll): 

7,  Ueei  ennlyticnl  expreeeion  for  lubgradient 
%  See  page  16  of  journal 

nitatei*Oiin( 1 ) ;  qcontrol>DiB(2) ;  edof sDim(5) ; 

a*v2*(v2'*(AA+Ll'*Cl)); 

Sy=a+a' ; 

Sw» ( (B2 • +D12  *  *L1 ) *72) •v2 • ; 
k«l; 

g2«zeros(edof ,1); 

for  i>l:nstates  %  eounte  out  diag  rove 

for  j>l:nstate«-«-l-i  X  counts  down  diag  rows 

if  i«*l, 

g2(k)*Sy(j,j): 

else. 

g2(k)-Sy(j,j+i-l)+Sy(j+i-l,j): 

end 

k*k+l: 

end 

end 

g2(k:  (k-*-qcontrolenstates-l))s2*reshape(S«,qcontrolenstates,l); 
7.  end  sttbgrad2C 


costgradc 

function  [Psi, g3] >costgradc ( f , V , Y , CO , 002 , Sf . Disi) 

7.  computes  the  cost  function/gradient  for  the  siixed  H2/Hinf  continuous  time 
7.  input  argument  1  selects  which  of  the  3  generalized  costs  is  to  be 
7«  implemented: 

7.  1*  trace 

7.  2«  max  eigenvalue 
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X  3*  MX  diagonal  antry 

nttatofsDiad) :  qcontrol>>DiB(2) ;  adof>0iB(8): 

L0>C0*Y-i'D02*V; 

M»L0*(Y\L0')*Sf : 

il  f«*l, 

Pai«traea(M) ; 
b*LO/Y; 

RY*CO»*b+b**CO-b**b; 

RV*2*D02**C0; 

•Iso, 

if  f**2, 

[V3.E3]»aig(ll); 

[Psi .  indaz]niaz(diag(E3) ) ; 
v«V3(: .indaz); 

•Isaif  f«B3. 

E3>diag(N);  . 

[Psi . indaz] BBaz(E3) ; 
v>zaros(langth(E3) ,1);  v(lndaz)>l: 

and 

a*C0'*v; 

b«(v'*LO)/Y; 

RY«a*b+b ' aa ’ -b  *  ab ; 

RV>2a(D02'av)ab; 

and 


ksi;  g3«zaros(sdof ,1) : 

for  i>l:aBtatas  X  counts  out  diag  rows 

for  jBl:nstatasai-i  X  counts  down  diag  rows 

if  iB«l, 

g3(k)-RY(j,j); 

also, 

g3(k)«2aRY(j,j+i-l); 

and 

k*kai; 

and 

and 

g3(k:  (kaqcontroianstatas-l))«roshapa(RV,qcontroianstatos,  1) ; 
X  and  costgradc 
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3.  Continuous  Mixed  7^2  /  Output-feedback  Synthesis  Codes 

This  section  lists  the  design  code  for  the  continuous  time  mixed  1^.2  /  'Hoo 
output-feedback  controller  synthesis  problem.  The  development  follows  exactly  the 
formulae  of  [Ref.  11]  in  constructing  a  auxiliary  plant,  solving  the  Hoc  filtering 
equation  by  Riccati  methods.  This  auxiliary  plant  is  then  fed  to  the  state-feedback 
controller  synthesis  code  above  (h2inf8yn). 
h2infopfb 


function  [K , Pi  1 1 ,  count , outeoai , t !■•]  >h2inf opf b(f ,  p , Din , aitr ,  ixit ) 

'/.  function  [K ,  Pi  i  1 ,  count ,  out  coni ,  t  ini]  sh2inf  opf  b  ( f,p,Din,nitr,exit) 

•/. 

*/i  Findi  output  foidbick  controller  for  (lub)optimal  nixid  h2/hinf  control. 

y. 

y,  Nithod  of  ivalunting  ginirilizid  aixid  h2/hinf  cost  function  cm  bi  iilictid; 
y.  f«l(traci),  2(Bax  oiginvalui),  or  3(nax  diag  olonont) 
y.  SyitiB  matrix  *p'  nuat  bi  a  packed  nu-tooli  lyiten  matrix: 

y. 


•/ 

Dim(l) 

DirnO) 

0iB(2) 

y. 

p  >  1  AA  1 

BI 

B2  1 

y. 

1  CO 

1  001 

002  1 

y. 

1  Cl 

1  on 

012  1 

0im(4) 

y. 

1  C2 

1  021 

022  1 

Dim(6) 

y. 

y,  nitr-  max  number  of  iteration! 

y,  exit-  termination  threshold  for  nixed  cost,  expressed  as  a  percentage 

y. 

y.  Outputs : 

y.  X-  dynamic  output  feedback  controller  in  packed  mu-tools  format 

y.  Psil-  Upper  bound  on  mixed  cost 

y,  count-  Returns  number  of  iterations  for  each  path 

y.  outcome-  textual  result 

y.  time-  elapsed  CPU  time 

y. 

y,  formulae  are  from  Rotea  md  Khargonekar,  CDC  Proceedings  12/91 


y,  unpack  system  matrices 
[AA,B.C,D]*unpck(p); 

nstateisDind);  qcontrol«0im(2);  pdistOimO); 

routputsDim(4) ;  motttput«Dim(6) ; 

noutO>ro«(C)-routput-moutput ;  pq*Dim(2)'fpdist ; 

ttsrow(D)-moutput ; 

B1*B( : , 1 :pdist) ;  B2bB( : .pdist+l  :pq) ; 

CO«C(l;noutO, : ) ;  ClBC((noutO'*'l)  :noutO-froutput, : ) ; 
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C2*C(  (noutO-froutput'f  1)  :ro«(C) , : ) ; 

D01«D(1 ;noutO, 1 :pdiat) ; 

DllsD(  (tt-routput'f  1 ) :  tt .  1 :  pdist ) ; 

D2lBD((nout04'routput'fl)  :roa(C)  ,l:pdiit): 

002>D(1 :  (tt-routput)  .pdiit'fl  :pq) ; 

D12sD((tt-rotttput'fl)  :tt,pditt-»l:pq) ; 

D22>D((noutO-«-routput-t’l)  :ro«(C)  ,pdist'»l:pq) ; 

pnoa«pck(AA,B,C(noutO<*'l:ro*(C) , :)  ,D(noutO-fl:ro«(C)  • : )) ; 

V.  Diiigniag  a  pura  hiaf  eontrollar 

diip( ’Daaigning  a  pura  hinf  eontrollar  to  datamina  faaaibility*) 

[Xhinl  .g.gf  in,  Ar ,  Ay]  ahinf  aynCpnoa.uotttput  .qcontrol  ,0 , 1 ,  .01 ) ; 
il  iaoaptydChinf )  • 

disp('Hinl  problaa  ia  lafaaalbla*) 
return 

elaeil  glin<«l, 

diapCHlnl  problaa  la  faaaibla') 

diap( 'Ganna  valua  above  ia  naasure  of  fraedon  for  B2  optinixation') 
end 

X  Solve  the  filtering  aquation 
C2tilde«aqrtn(D21*021 '  )\C2: 

han-CAA'  (Cl'eCl-C2tilda*eC2tilda);-Bl*Bl'  -AA]; 

[ql ,  q2 ,  fail ,  aig.nin]  «rle.acbr  (ban) ; 
if  fail>0. 

error( 'filtering  aquation  troublea') 
end 

q«q2/ql:  q-Q+q'/25 

if  nin(aba(aig(q)))<’-le-10, 

errorCq  ia  not  poaitiva  definite') 
end 

'/.  build  the  auxiliary  plant 
AAa*AA-t^qeCl'*Cl; 

Bla*q*C2tllda': 

B2a*B2-»q*Cl'eD12: 

D01>xeroa(rov(D01)  ,noutput); 

Dll«zero8(routput,noutpnt) ; 

pauz«pck(AAa.  CBla.B2a]  ,  [COjCl]  .  CD01,002;D11.D12]> ; 

sf«co*q*co' : 

0iaa>CDin(l),col(B2a)  ,col(Bla)  ,ro«(D01),natataa*(natataa'fl)/2'*>natate8*col(B2a)] ; 

%  Design  a  state-feedback  nixed  controller  for  the  auxiliary  plant 

[Kip, Kp,X,E, count. Pail. Pal2,outcoae, tine] >  h2infsyn(f  ,paux, Dina, Sf.nitr, exit) ; 

%  Build  the  dynanic  controller 

K«pck((AAa-Bla*C2tilda4'B2aeXlp)  ,Bla,Xlp,zaroa(qcontrol,noutput) ) ; 


y.  end  h2inlopfb 


C.  DISCRETE  TIME  MIXED  /  Hoc  CONTROLLER  SYNTHESIS 

As  discussed  in  Chapter  III  and  (Ref.  12],  the  mixed  output-feedback  control 
problem  is  based  upon  a  convex  expression  of  the  full-information  problem.  It  can 
be  solved  by  the  solution  of  a  filtering  Riccati  equation,  and  the  construction  of  an 
auxiliary  plant  for  which  a  full-information  controller  is  designed.  This  section  con¬ 
sequently  develops  and  lists  the  state-feedback  controller  synthesis  tools  which  could 
either  be  used  independently,  or  called  by  the  output-feedback  synthesis  function. 
Furthermore,  in  the  absence  of  commercial  Hoc  synthesis  tools  for  discrete  time,  a 
measurement-feedback  code  was  written,  based  on  Riccati  methods.  It  was  helpful 
both  for  assessing  the  feasibility  of  example  problems,  and  also  formed  the  structural 
basis  for  the  mixed  H^  /  Hoc  synthesis  routine.  This  section  consequently  concludes 
with  listings  of  both  the  discrete  Hoc  and  H-i  /  Hoc  synthesis  codes  for  measurement 
feedback  controllers. 

1.  Numerical  Solution  of  the  Discrete  Time  Full-Information  Prob¬ 
lem 

This  section  outlines  the  development  of  the  ellipsoidal  design  codes  for  the 
discrete  mixed  H2  /  Hoc  full-information  controller  synthesis  problem.  Recall  from 
Theorem  3.5  that  the  problem  can  be  expressed  as  a  convex  optimization  problem: 
Minimize: 

/.■(A/(lF,r,/v,)):= 

/.  {(CoK  +  Do2W)Y-HCoY  +  Do2Wf  +  (Doi  +  /?02 A'2)(£)oi  +  Do2J<2f}  , 

(A.7) 


149 


Subject  to:  K  >  0,  and  L{W^Y,  I\‘2)  <  0, 

where 


L{W,Y,I<2):= 


AY  +  B,W  1  , 

AY  +  BiW 

CxY  +  DuW 

B\  R2A2  B\  -f-  B2l\2 

T 

'  Y  0 

D\\  +  D12K2  B\\  -|-  D12A2 

0  I 

(A.8) 

and  /i  is  the  trace,  /j  is  the  maximum  eigenvalue,  or  fs  is  the  maximum  diagonal 
element. 


The  structure  of  the  code  is  very  similar  to  the  continuous  codes  above. 
Two  items  are  of  significance  which  warrant  independent  discussion.  First  of  all,  the 
structure  of  the  controller  is  different  for  the  discrete  problem,  in  that  it  is  now  a  full- 
information  feedback  gain  matrix,  rather  than  state-feedback.  The  parameterization 
of  the  controller  is  now  A'/,  =  (VFi'"*  A'’2|,  necessitating  that  the  search  has  an 
additional  p  x  q  degrees  of  freedom,  where  p  :=  dim  (te)  and  q  :=  dim  (u).  A  set  of 
basis  matrices  A'2,  €  was  consequently  constructed  with  identical  structure  as 
the  set  of  VF,  above.  The  second,  and  more  challenging  issue  was  the  determination 
of  an  initial  feasible  controller.  This  was  necessary  in  order  to  assess  the  feasibility 
of  the  problem  and  to  give  the  iterative  ellipsoidal  search  a  good  starting  point.  To 
this  date,  no  commercial  codes  are  available  to  solve  the  discrete  time  Riccati 
equations,  and  so  considerable  effort  was  devoted  to  cleanly  solving  these  problems. 
The  codes  for  these  problems  are  included  here  as  subroutines  to  the  main  script. 


1.  Determine  if  the  Hoo  problem  is  feasible,  and  determine  a  particular  feasible 
controller  Kp  =  [A'l^  A'2^].  This  was  done  by  solving  the  discrete  time  Hoo 
synthesis  equation  [Ref.  31]. 
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2.  Determine  Vp  and  Wp  =  KpYp  from  tlie  analysis  equation  (3.2). 

3.  Initialize  the  search  at  x  =  [0, . . .  ,0]^ ,  with  a  very  large  ellipsoid  about  x. 

4.  Fromx,  determine  Y,  W,  and  A'2  as  perturbations  of  the  particular  solution 
{Wp,Yp,K2p). 

5.  Evaluate  the  constraint  ^i(x)  =  ATOar(-F)  <  0.  If  <i>\{x)  >  0,  then  use  the 

eigenvector  associated  with  the  maximum  eigenvalue  to  calculate  the  subgradi¬ 
ent:  gi  =  Update  the  ellipsoid  and  x  and  return  to  step  4. 

6.  Evaluate  the  constraint  ^2(3  )  =  Amor(^(fU,  F, /\2))  <  0.  If  4>2{x)  >  Ot  then 

use  the  eigenvector  associated  with  the  maximum  eigenvalue  to  calculate  the 
subgradient:  52  =  Update  the  ellipsoid  and  x  and  return  to  step  4. 

7.  With  both  constraint  functionals  satisfied,  evaluate  the  objective  function  V’(a;)  = 
/(W,  y,  A'2))  and  its  subgradient:  «/3  =  Update  the  ellipsoid,  i,  and  the 
upper  and  lower  bounds  on  the  estimate  of  the  optimum  cost. 

8.  Return  to  step  4  unless  the  termination  criteria  is  satisfied. 

9.  Calculate  the  (sub)optimal  controller  A'  =  [W'}''"'  A'2]. 

10.  Exit. 

The  discussion  above  in  section  B,  regarding  computational  issues,  is  also 
germane  to  these  codes. 

The  analytical  expressions  for  the  subgradient  expressions  are  derived  be¬ 
low.  Recall  that  u  is  the  eigenvector  as.sociated  with  the  maximum  eigenvalue.  The 
first  subgradient  g\  is  omitted  since  it  is  identical  to  the  continuous  time  problem. 
Due  to  the  structure  of  L{W,  Y,  A'2),  it  is  easiest  to  break  the  gradient  expression  for 
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g2  into  its  respective  parts.  Additionally,  the  replacement  K\  =  WY~^  is  made  when 
convenient. 


92,  = 


For  t  =  1  to  .j.  nq,  1\2,  =  0: 

dMx) 


=  u 


=  u 
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For  i  =  +nq  +  \  to  +  (n  +  p)q,  Vj  =  0  and  VF,  =  0: 
d<t>2[x) 
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(A.IO) 


The  subgradient  for  the  co.st  functional  will  first  he  derived  for  /2,  and  then 
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modified  as  above: 


</3.  = 


dh{x) 

dxi 


,dM{W,YJ<2) 

=  «  - - u 


=  u'^{{CoY^Do2W)Y-HW-\-Do-iWf 

+  (■^01  +  Dq2K2){Dq\  +  £)o2A'2)^|« 

=  «‘|[Co  Z)02]  (Co  +  Do2/m)^  +  (Co  +  Do2A'i)[v;- j|« 

-vT  {(Co  +  Do2Kx)Yi{Co  +  /)o2A',r}  « 

«*  {+i5o2A2;{/?OI  +  Dq2I\2V  +  (^01  +  /^02A'2)A^Z)o2}  “ 

=  2  tr|(Co  +  /)o2A',rtiu-[Co  D^]  |  ^  j  | 

+tr  {(Co  +  Do2KxVuu\Co  +  Do2l<i)Yi} 

+2tr{(Z)oi  + /5o2A2)^t<«'^o2A2,|  •  (A. 11) 


dxi 


The  gradients  of  /i(H^, K,  A'2))  and  MW^Y^Kz)  are  then  minor  modifications  [Ref. 
29].  For  /i,  replace  u'u  with  the  identity  matrix  I.  For  /s,  replace  u  with  the 
elemental  vector  e,  =  [0, . . . ,  0, 1, 0, . . . ,  0]^,  where  the  unit  digit  corresponds  with  the 
position  of  the  maximum  diagonal  element. 

2.  Discrete  Time  7^2  /  "Hn  F\iU-Information  Controller  Synthesis  Codes 
This  section  lists  the  di.screte  mixed  H2  /  Hoo  state- feed  back  controller 
design  codes.  The  function  dh2infsynl  is  the  principal  script.  The  function 
h2inffonn  is  an  administrative  script  that  maps  the  vector  x  into  W,  Y,  and  A'2. 
The  functions  df  iric2  and  dhinf  ric  solve  the  discrete  synthesis  and  analysis 
Riccati  equations.  Finally,  the  functions  subgradl,  subgrad2,  and  costgradlc  cal¬ 
culate  the  subgradient  vectors  for  the  two  constraint  functionals  and  the  cost  function. 
Note  that  subgradl  is  identical  to  its  continuous  time  counterpart  and  is  included 
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here  simply  for  completeness.  The  coding  of  the  suhgradients  was  the  difficult  part  of 
the  development,  and  the  codes  were  validated  (and  the  multiple  errors  corrected)  by 
comparison  with  gradient  vectors  which  were  determined  by  brute  force  perturbation 
methods  (i.e.,  gi  =  where  e,  =  (0, . . .  ,0, 1,0, . . .  ,0]^  ). 

dh2infsynl 


function  [K, Kp,X,E, count, Pall  ,Psi2,outcoa«,tiBa]B. . . 

dh2inlaynl(f  ,pd, 01b, Sf,Bitr,«zit,Xi.  Ei,  count!,  Palli,Pai2i) 

'/.  function  [K, Kp,X,E, count, Pail ,Psll2,outcoBa,tlBa]s. , , 

'/,  dh2infaynl(f  ,pd,Dla,Sf  ,altr,azit,Xi,  Ei,  count!,  Paill,Pai2i) 

•/. 

y.  Finds  full  infornstlon  faadback  gains  for  DISCRETE  (sub)optiBal  Bixad  h2/hinf 
y.  control.  Solvss  for  appropriate  fi  gains  vith  which  to  build  output  faadback 
y.  controller  if  input  'pd*  is  auxiliary  plant. 

y,  Hinf  constraint  is  applied  as  infnorB(Tzlu)<l.  Different  values  of  ganaa 
y.  Bust  be  absorbed  into  the  appropriate  rose  of  the  plant  aatrlx. 

y. 

y.  Inputs: 

y.  Method  of  evaluating  generalized  aixed  h2/hinf  cost  function  can  be  selected: 
y.  f>l(trace),  2(Bax  eigenvalue),  or  SCaax  diag  elaaent) 
y.  System  matrix  *pd’  aust  be  a  packed  au^tools  systea  aatrlx, with  the  noted 
y.  dimensions: 

y. 


Din(l) 

DlrnO) 

DiB(2) 

1  AA 

1  B1 

B2  1 

pd« 

1  CO 

1  DOl 

D02  1 

1  Cl 

1  Dll 

D12  1  Dim(4) 

y. 

y.  lots:  the  columns  and  rows  associated  vith  the  input  v  and  the  output  zl 

y,  must  have  been  sealed  for  gaaaasl 

y,  'Din*  holds  the  descriptions  of  the  problem  size: 

y.  Din(6)«sdof«Dia(l)*(Dla(l)>l)/2  *  DiB(2)*(DiB(l)'t^DiB(2}) 

y,  'Sf '  is  the  filtering  cost  matrix  for  the  output  feedback  problem  and 

y,  should  be  set  to  zeros (nstates)  for  full  info  feedback  problem 

y.  'aitr'  is  the  max  number  of  iterations 

y,  'exit*  is  the  exit  criteria  as  fraction  of  the  cost 

y.  The  remaining  input  variables  are  for  restarting  a  problem  that  had  not  yet 
y.  reached  convergence  and  should  be  empty  for  initialization. 

y. 

y.  The  outputs  are  the  gain  matrix  K«CK1,K2],  the  central  controller  Kp,  and  the 
y.  stopping  paranetrics  which  provide  for  restart  capability  if  the  problem  had 
y,  not  yet  converged,  'outcome'  identifies  the  termination  branch  followed. 

y. 

y.  Constraints  are  applied  using  the  formulation  of  Tha  4.3  from  Kaminer, 
y,  Khargonekar  and  Rotaa.  This  is  the  TVO  STEP  contraint. 

y. 
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'/.  This  vsrsion  usss  NATLAB's  ’sig*  to  svaluats  positivs  dsfinitsnsss 

'/tiBsscputisia; 
outcoBo« 'max  itsrat ' ; 

y.  unpack  systtn  aatricss 
[AA . B , C ,D] *anpck(pd) ; 
sdolsDia(5) ;  nstatasaDiad) ; 

pdist«Din(3):  routputaDia(4) ;  ttsro»(C);  pqBDla(2)'«'pdist; 

BlaB(:  ,l:pdist) ;  B2>B(:  ,pdist'fl:pq) ; 

COsCd : (tt-routput) , : Cl«C((tt-routput+l) :tt, : ); 

001«Dd :  (tt-routpnt) .  1  :pdist) ; 

01 1«D(  (tt-routput't'l ) :  tt .  1 :  pdlat ) ; 

D02«Dd :  (tt-routput)  ,pdlst'»l  :pq) ; 

D12aD(  (tt-routput'fl ) : tt  .pdlst'fl  :pq) ; 

y.  Dstamina  fsasibility  and  spsciflc  solution  (central  controller) 

y.  Solve  the  synthesis  Riecati  equation 

[Kip, K2p.P, Parr. arllg]-dfiric2(AA,Bl.B2. Cl. Dll. 012. 0.00); 

if  erflg>l. 

outcome*  * IIFBASIBLI * ;  return 

end 

Kp*[Klp.K2p] : 

X  Solve  the  analysis  equation 

CYp.erflg]>dhinfric((AA4^B2«Klp)  *  .(Cl-t-D12*Xlp)‘.(Bl^B2*K2p)  *  .(Dll-t^D12*K2p) '  .0.00); 
if  erflg>0. 

outcome* ‘ IIFEASXBL2' ;  return 
end 

Wp*Klp«'Yp; 

y.  Initialixe  problem  or  use  last  value? 

y.  This  is  a  weak  point  in  the  code  right  now  as  it  initializes  the  ellipsoid 
y.  as  something  arbitrarily  huge,  lead  to  find  a  way  to  initialize  the  ellipsoid 
y.  in  a  smarter  way. 

count*[0  0  0];  Psll*lnf;  Psi2*0;  thresh*0; 

Xszeros ( sdof . 1 ) ;  E*  100*eye ( sdof ) ; 

if  nargin>6. 

count«counti;  Psil*Psili;  Psi2*Psl2i; 

X*Xi;  E*Ei; 

alseif  nargin<6. 

error( 'insufficient  number  of  input  arguements’) 

end 

Z*zeros(nstates .rontput) ;  gam*l ; 

for  k*l:mitr. 

[U.Y.K2]*h2infform(X.Vp.Yp.K2p.Dim):  %  maps  X  to  (V.Y.K2) 

y.  Enforce  Y>0 
CVy.Ey]»eig(-Y); 

[Phi 1. index 1] *naz (diag(Ey) ) ; 

15.5 


il  Phil>0, 

gBiubgradlc(Vy( :  ,ind«xl)  ,nstat«s  ,sdof ) ; 

Eg*E*g:  g*g«iqrt(g**Eg);  Eg>Eg/gAg; 

11  Phil>gAg, 

outcoH*>  * indalinit* ' ;  raturn 

•nd 

alpha«Phil/gAg; 
count«count'«’[l  0  0]; 

'/.  Enlorea  inlinity  non  constraint 

alto, 

Kl*«/Y; 

a>  CAA-^B2«X1  :  C14D12*K1] ; 
b*CBl-i-B2*K2:Dll^D12aK2] ; 

L«a*y*a  *  +b*b  * - [Y , Z ; Z ’ , aya  (routput )] ; 

[Vlnf  lElnl]  "aigCD ;  CPhi2 ,  indax]  ■nax(diag(Einl) ) ; 

il  Phi2>thrath. 

g«attbgrad2(Kl,K2.Vlnl( :  ,indax),Dia.AA.B2.Cl,012.a,b); 
Eg*E*g;  gAg«aqrt(g**Eg);  Bg«Bg/gAg; 

il  Phi2>gAg, 

outcona* ' inlaaaibla ' ;  raturn 
and 

alpha«Phi2/gAg: 
count«eotint4C0  1  0]; 

y,  Oivan  abova  ara  aatialiad,  lollos  coat  gradient 

alia, 

CPai,g]«costgrad(l.Y.Kl.K2,C0.D01,D02.Din.Sl); 

Eg*E*g:  gAg>aqrt(g**Eg):  Eg*Eg/gAg; 

Psl2«Mx(C(Pai-gAg)  :Pal2] ) ; 
il  PaKPsil. 

Pall>Pai;  alpha«0; 
alaa 

alpha«(Pai-Pall)/gAg; 

and 

count>count-fCO  0  1]; 

y.  Exit  critaria 
il  gAg<axit<*Paii , 

diapCProgran  convargad  to  solution ') 
outcona  >  'convargad!';  break 

and 

and 

and 

X>X-Eg*(  (l4'adol*alpka}/(adol-»'i) ) ; 

EaE-2*Ega  (Eg '  *(  ( 14sdol*alpha)/(sdol-<'l )/( I't’alpha) ) ) ; 
E>E*((l-alpha‘2)*adol*2/(sdol*2-l)); 

E>(E-«’E')/2;  X  anlorca  aynatry 
and 

Xt  iBa>  eput  iaa-t  laa ; 
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if  outcon*  »  *convarg«d! ' , 

K=[K1  K2]; 

•nd 

Folloving  ur«  called  noa-organic  funetiona: 

'/.  function  [W,Y,K2]Bh2inffoni(X,Vp,Yp,K2p,DiB) 

%  function  gl«iubgradl(vl,nttatat,sdof ) 

'/.  function  g«aubgrad2(Kl,K2|Vinf  ( :  ,indax),Dia,AA,B2,Cl,D12,a,b) ; 

*/,  function  [Pti,g]>coatgrad(f ,Y.Kl.K2.C0.D01.002.Din,Sf); 
y.  function  Sya>pck(a,b,c,d)  fron  nu-toola  toolbox 
y.  function  [Fl,F2.P.Parror,arflg]*dfiric2(A.Bl,B2.C,Dll,D12.gan) ; 
y.  function  [Yp,arflg]>dhinfric(F,G,H, J ,gaa) : 

y.  and  dh2inf8ynl 


tlfilic2 


f unct ion  [FI , F2 , P , Parror , arf Ig] ^df iric2(A,Bl,B2,C,Dll,D12, gan) ; 
y.  CFl.F2.P,Parr,arflg]  «  DFIRIC2(A.Bl.B2.C.Dll.D12,gaB): 

y. 

y.  Thia  routine  aolvaa  the  Diacrata  Algebraic  Riccati  aquation 
y.  for  the  full  infomation  h-infinity  problan: 
y.  Find  a  P  auch  that: 
y.  V(P)  >  B2'PB2fDll*Dll  >  0 

y.  R(P)«ga»*2*I-Dll  'Dll-Bl  'PBl+CBl  •PB2+011  *0i2)*ia»(V(P)  )a(Bl  'PB2+D11  *012)  *>0 

y. 

y.  and  the  DARE:  P  «  A*PA  *  C'C  •  Xb*inv(G(P))*Xb* 

y. 

y.  ia  aatiafiad  with: 

y.  G(P)  >  C  Dll 'Dll  *  Bl'PBl-  gaii*2I  D11’D12  t  BrPB2  ; 

y.  D12'D11  *  B2'PB1  D12'D12  *  B2'PB2  ] 

'/.  Xb  >  A'P[B1  B2]4-C'C011  D12]; 

y. 

y.  where  u(k)  «  CFl,F2]a[x(k) '  w(k)']'  the  aolution  to  the  full  infonation 
y.  caaa.  The  aolution  ia  baaed  on  Igleaiaa*  ayaplectic  pencil  fonulation. 
y.  VARIIIG:  The  input  argunent  order  ia  different  fron  Stoorvogel'a'dfiric'  to 
%  nake  the  fomulation  conaiatent  with  Rotea  and  Xaninar'a  notation. 

y. 

y.  The  following  inorganic  natlab  funetiona  are  called: 

'/.  abcdchk2 

'/.  begin  dfiric2 

erf IgsQ : 


y.  CHECK  THE  COISXSTEICY  OF  THE  MODEL  NATCHIHG  PROBLEM 

Cnl,n,p,nagl]«abcdehk2(A,Bl,C,Dll); 
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[■2,n,p,asg2]«abcdchk2(A,B2.C,D12) ; 

if  ‘(iirapty(m>gl)  t  l*Mipt]r(Bag2)) , 

<lltp( 'ERROR  II  THE  REALZZATIOI ' ) ; 
diap(Btgl) .diip(Bag2) 

•rllg>2; 
return ; 

•nd 

Ip>:«y«(al};  Ir^eyeCp);  In>«y«(n); 

Znsz«roi(n) ; 

Rl-inv([Dll**Dll-Zp*gUi“2,  Dll '*012;  D12'*D11,  D12**D12]); 

'/.  aynplectlc  pencil  for  DARE: 

SIHP1«C  A-[B1  B2]*R1*CD11  D12]**C.  Zn 

-C**(Zr-CDll  D12]*R1*CD11  D12]‘)*C.  In  ]; 
SZIF2>C  In  .  CBl  B2]*R1*CB1  B2]  * 

Zn  .  (A-[B1  B2]*R1*CD11  D12]'*C)>]: 

[Ve ,Ti] seig(SIIFl ,SIIF2) ; 

Ta*ding(Ti); 

if  ■in(nbe(log(aLbe(Ta))))<(10000*epa), 
diapCHaaiiltoninn  ia  net  in  doa(Rlc)*), 
erflg*3i 
return 

olae, 

indexl>f ind(aba(Ta)<l) ; 

P^Va  (n-*’ 1 :  2*n ,  index  1 ) /Va  ( 1 :  n ,  index  1 ) ; 

P>real(P) ; 

p»(p+p»)/2:  54  Enaurea  P«P' 

and 

54  Verify  accuracy  of  aolution 
GP*inv(inT(Rl)+CBl  B2]’*P*CB1  B2]); 

Xb>A'*P*[Bl  B2]eC'eCDll  D12]: 

Perror-  A'*P*A  -  P  ♦  C**C  -  Zb*GP*Xb’; 

accuracy>(norai(Perror)/aora(P) ) ; 
if  accuracy>le-6, 

diap(*  Warning:  Solution  to  DARE  aay  be  inaccurate*); 
accuracy 
erflg*l; 
end 


54  Check  for  atability 
AcloaaloopaA'CBl  B2]oGPeXb’; 
if  ■ax(aba(eig(Acloaeloop)))>«l, 

diap('Cloaed  loop  ayatea  not  atable*) 
erflgsd; 
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return 

end 

VPi  »  pinv(B2'*PeB2O12**012); 
FI  =  -VPi*(B2’*PeA*D12'*C): 

F2  =  -VPie(B2**P*Bl+D12'*Dll); 
return 

*/.  end  dlirlc2 


dhinfric 

function  CY,erflg]«dhinfrie(F,G,B, J.gUB); 

*/.  [Y .  erf  Ig]  Bdhinf  ric  (F ,  G ,  H ,  J ,  gen) ; 

•/. 

'/•  This  routine  solves  the  Hinf  Discrete  Algebrsic  Riccsti  equation  for  a  closed 
loop  system  F,G,H,J. 

•/. 

Find  a  Y  such  that: 
y.  R  «  gam'2*I  -  J'eJ  -  G**YsG  >  0 
•/.  FYF»  -  Y  ♦  GG*  ♦  (FYH*  +  GJ')*R\(HYF’  ♦  JG*)  *  0 

y. 

y.  The  solution  is  based  on  Xglesias*  synplectic  pencil  formulation  (eqn  2.6) 
y.  Calls  chol2  and  rov  from  ktools 

Cn  m]asise(G): 

Ragam‘2*eye(m)-J ’ej ;  F»F+G*(R\J ' )*H; 

'/t  form  Symplectic  pencil 

Sls[F  zeros(n,n);  -H’*inv(eye(rou(J))-J*J*)*H  eye(n)]; 

S2«[eye(n)  -G*(R\G*):  zeros(n,n)  F']; 

[Vs.Ts]aelg(Sl.S2);  Tsadiag(Ts);  indezl>find(abs(Ts)<l) ; 

if  min(abs(log(abs(Ts))))<(10000*eps) , 
erf Igai ;  return 

and 

Y»real  ( Vs  (n+1 :  2*n ,  indezl )  /Vs  ( 1 :  n ,  indexl ) ) ;  Y»  (Y+Y ' )  /2 ; 

if  (chol2(Y,n)'«l)  I  (chol2((R-G’*Y*G) ,m)'sl) , 
erflgal;  return 
end 

erflgaO; 
y.  end  dhinfric 


h2infForm 
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function  CW.Y.X2]>h2inffon(X,Vp,Yp,XIiinf2.0iB) 

%  roforaati  tho  spnca  Z  in  Ha  to  tho  thro*  untricoi 

y,  X  if  ntauaad  to  ba  coapriaad  of  tha  diagonal  roaa  of  Y,  atarting  with  tha 
X  aain  diagonal,  folloaad  bj  V  in  coluan  ordar,  and  laatly  by  K2  by  column 

natataa«Din(l):  qcontrolBDiB(2) :  pdiat«Dim(3) ;  adof«DiB(6); 

jsnatataa; 

YsYp'*'diag(X(l:natataa)): 
for  ksi;natataa-l, 
i>natataa-k; 

Y«Y+diag(X(  j+1 :  j+i)  ,k)+diag(X(  j+1 :  j+i)  .-k) ; 
and 

WsVp't-raahapaCXC  j'fl :  j*natataa*qcontrol)  ,qcontrol,natataa) ; 
K2«Khinf2-«-raahapa(X(  j'fnatataaaqcontrol'fl  :adof )  ,qcontrol,pdiat) ; 

y,  and  h2infforB 


subgrad 1 

function  gl «attbgrad  1  ( v , natat at , adof ) 

y.  calculataa  anbgradiant  for  firat  conatraint  function  Y>0 

gl»zaroa(adof ,1) ; 
k=l; 

for  i«l:natataa  X  counta  out  diag  rowa 

for  j«l  rnatataa-^l-i  X  counta  doun  diag  rout 

if  i»«l, 

gl(k)«-v(j)*tf(j); 

alaa, 

gl(k)»-2*v(j)*T(j+i-l): 

and 

k»k+l ; 

and 

and 

X  and  aubgradl 


subgrad2 

function  g2«aubgrad2(Kl,K2,v2,DiB,AA,B2,Cl,D12,a,b); 
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y.  Utas  analytical  axpraation  lor  aubgradiant 
y.  Sat  paga  16  of  journal 

natataa«DlM(l) :  qcontrol»Diai(2) ;  pdiat«Diai(3) ;  adof«Dia(5); 
ab«a'av2; 

ac*ab*(v2**CAA;Cl]): 

bd=(v2'*[B2;D12]); 

Sycacfac ’ -abaab ’ ; 

Sv«ab*bd; 

Sk«(b’*v2)*bd: 

k=l: 

g2szoroa(adol,l) ; 

lor  i«l:natataa  X  counta  out  diag  roua 

lor  j*l:natataaai-i  X  counta  dovn  diag  rova 

il  i**l, 

g2(k)-Sy(j,j)-v2(k)‘2: 

alaa, 

g2(k)*Sy(j,j+i-l)+Sy(j+i-l.j)-2*v2(j)*v2(j+i-l): 

and 

k*k+lj 

and 

and 

g2  (k ;  (kaqcontrolanatataa- 1 } )  «2araahapa  (Sh  ,  qcontrolanatataa ,  1 ) ; 
g2((k'<-qcontrol*natataa)  :adol)s2araahapa(Sk,qcontrolapdiBt,l) ; 

X  and  aubgrad2 


costgrad 

lunction  [Pai3,g3]>coatgrad(l.Y.Kl,K2.C0.001,D02.Diai,Sl) 

X  lunction  [Pai3,g3]acoatgrad(l,Y,Kl,K2, CO, 001,002, Dial, 51) 

X 

X  FOR  USE  WITH  DR21IFSYI 

X  conputaa  tka  coat  lunction  lor  tha  nixad  H2/Hinl  diacrata  tiaia 
X  input  arguaiant  1  aalacta  which  ol  tha  3  ganaralizad  coata  ia  to  ba 
X  inplaaantad: 

X  1*  traca 

X  2>  max  aiganvalua 

X  3«  Bax  diagonal  antry 

X  alao  datarainaa  tha  aubgradiant  lor  tha  coat 
X 

X  calla  row  (ktoola) 

adol«0iB(6);  natataaBOiaCl) ;  qcontrolB0iB<2) ;  pdiat«0in(3) ; 
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dkl>D02*Xl; 

asCO-fdkl; 

b>D01+D02*X2: 

N«a*Y*a ’ +b*b ’ +Sf ; 
il  1««1, 

Psi3*trac«(M): 

RY*CO**CO-dkl**dkl; 

RVB2*D02'*a; 

RX2«2«002'*b; 

alaa, 

il  1**2, 

[V3,E3]«aig(M); 

CPai3 . indax] ■■ax(diag(E3} ) ;  v»V3( : . indax) ; 

altail  1**3, 

[Pal3, indax] *max(diag(N));  v*zaroa(rov(N),l):  vdndax)*!; 

alsa, 

arror('lirat  input  arguaant  nuat  ba  1,2, or  3*) 
and 

a*CO'*v; 

d*D02'«v; 

dkl*d**Xl: 

RX2*2*d*  (  V  •  oDOl-t-d  '0X2): 

RY*aaa*-dkl'*dkl: 

RU*2«d«(a'4^dkl): 


k*li  g3*xaroa(adol,l): 

lor  i*i:natataa  %  counts  out  diag  rows 

lor  j*l:nstatos4'l-i  X  counts  down  diag  rows 

il  i**l, 

g3(k)«RY(j,j); 

alsa, 

g3(k)*2*RY(j,j+i-l): 

and 

k*k-i-l; 

and 

and 

g3(k:  (k-<-qcontroianstataa-l))*rashapa(RV,qcontrolanstatas,  1) ; 
g3(  (k4^qcontrol*nstatas) :  sdol  )*rashapa(RX2,qcontroiapdist ,  1 ) ; 

X  and  costgrad 
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3.  Discrete  Hoo  Output-Feedback  Controller  Synthesis  Problem 

The  following  design  code  was  prepared  to  solve  the  discrete  'Koc  output- 
feedback  controller  synthesis  problem.  In  the  absence  of  commercial  codes  to  solve 
this  problem,  this  code  was  useful  to  assess  the  feasibility  of  synthesis  models  prior 
to  attempting  the  mixed  /  Hoo  problem.  Specifically,  the  value  of  achievable 
7  for  the  Hoo  controller  was  a  measure  of  the  degree  of  freedom  available  to  the 
H2  optimization.  The  Hoo  problem  is  solved  by  sohition  of  the  filtering  equation  by 
Iglesias’  symplectic  pencil  method  (Ref.  47],  and  then  construction  of  an  auxiliary 
plant  per  Stoorvogel  [Ref.  31). 


dhinfsyn 


function  Ck , gf in]  «dhinf tyn(pd , qcontrol  .aoutput . logan , higui , tol ) 

*/•  function  [k,gfin]>dhinfsyn(p<l,qcontrol,aoutput, logan, higan, tol) 

y. 

y.  Oataminaa  discrata  tina  controllar  vhich  ainiaiaaa  tha  infinity 
y,  norn  of  v  to  a  (to  within  tha  apacifiad  tolaranca). 
y.  Tha  diacrata  ayataa  P  ia  partitionad  (par  au-toola): 
y.  I  a  hi  b2  I 

y.  P  *  I  cl  dll  dl2  I 

y.  I  c2  d21  d22  I 

y,  whara  b2  haa  column  aiza  of  tha  nuabar  of  control  input a  (qcontrol) 

y,  and  c2  haa  row  aiza  of  tha  nunbar  of  naaaurananta  (noutput)  baing 

y.  providad  to  tha  controllar. 

y.  dhinfayn  calla  dflric2,  row,  col  (paraonal  codaa)  and  unpck  from  nu-toola 
y.  toolbox 


[AA , BB . CC .DD] >unpck (pd) ; 
nzlsrow(CC)-aoutput ; 

B1«BB(: ,l;nwl) : 
Cl»CC(l:nzl,:); 
Dll«DO(l:nzl,l:nwl) ; 
D21>DD(l-*'nzl:rov(CC),l:nwl); 


nwl=col(BB)-qcontrol ; 

B2«BB(:  ,nvi'<-l:col(BB)); 
C2«CC(nzl-»^l:row(CC) , : ) ; 
D12«0D(l:nzl,nwl4'l:col(BB)) : 
D22«DD(l't'nzl;rov(CC)  ,nwl'«'l:col(BB}) ; 


ganl«higan;  gaB2>logaa;  gaa«ganl; 

Ia=aya(Dll*Dll * )-Dll*Dll * ; 

whila  (ganl-gaiB2)/gaal>tol, 
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*/.  solve  the  liltsring  equation 

CLl,L2,Q,Qsrror,srflgl]>dflric2(AA*  ,C1',C2'  ,B1'  .Dll'  ,D21  ’  .ga«) ; 
if  arflgioi. 

*/.  Build  Gfi(Q),  tha  augusntsd  plant 
V*C2*q*C2*-i-D21*D21': 

R«Ia-Cl*Q*Cl'+Cl*q*C2'*(V\C2*Q*Cl'): 

Z»AA*q*Cl*+Bl*Dll'“(AA*q*C2'+Bl*D21»)*(V\(C2*q*Cl  *+021*011')); 
Vhalf*lnv(sqrta(V)) ; 

Rhalf«inv(sqrta(R)) ; 

AAq«AA+Z*(R\Cl): 

Blq>(AA*q*C2'+Bl*021'+Z*(R\(Cl*q*C2'+Dll*D21')))*Vhalf : 
B2q*B2+Z*(R\D12); 

Clq*Rhalf *C1 ; 

Dllq«Rhalf*(Cl*q*C2 '+011*021  *)*Vhalf; 

D12q*Rhalf*D12: 

%  Mow  solva  for  tha  full-info  gains  which  satisfy  tha  hinf  prob 
[Kla,K2a.P.Parror,arflg2]>dfirie2(AAq.Blq,B2q.Clq.Dllq.D12q,gaB) ; 
if  arflg2<«l. 
gaalcgasi; 

gasi3(gaa+gaB2)/2:  disp(gaa) 

and 
and 

if  Bax(C*rflgl:arflg2])>*l, 
if  gan»higaai, 

arror( 'problaa  not  faasibla  within  spacifiad  ganM  range') 
and 

gaB2«gaa; 

gaB*(gaa+gaail)/2;  dispCgan) 

else, 

Xl*Kla;  K2>K2a: 
and 
and 


'/.  Build  hinf  controller 
Ac*AAq+B2q*Kl-(Blq+B2q*X2)*Vhalf*C2; 
Bc*(Blq+B2q*X2)*Vhalf; 
Cc«Xl-X2*Vhalf*C2: 

Dc«X2*Vhalf ; 
k*pck(Ac,Bc.Cc,Dc) ; 
gfinogaal; 

*/.  and  dhinfsyn 
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4.  Discrete  H2  /  Hoo  Output- Feedback  Controller 

The  following  function  file  solves  the  discrete  H2  /  “Hoo  output-feedback 
controller  synthesis  problem.  It  is  based  upon  the  optimal  discrete  code  above 
and  differs  principally  in  that  after  the  auxiliary  plant  is  constructed  it  calls  the 
dh2inf  syn  to  solve  the  mixed  full-information  state- feed  back  controller  problem.  As 
with  the  continuous  codes,  w  and  c  are  assumed  to  have  been  scaled  in  order  that 
the  constraint  ||  ||oo<  1  is  feasible. 


dh2infsyn 


f  unct  ion  [K .  count  ,Pail,Pti2,  out  cob*  ,  t  1b*]  sdh2ini  opf  b  (f,pd.DiB,Bitr,*xit) 


•/. 

•/. 

y. 

•/. 

•/. 

•/. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 

y. 


Find*  lull  infomation  f**dback  gain*  lor  DISCRETE  (aub)optlBal  Bix*d  h2/hlnl 
control.  Solv**  lor  appropriate  li  gains  vith  shich  to  build  output  l**dback 
controller  il  input  *pd'  la  auxiliary  plant. 

Hinl  conatraint  ia  applied  as  inlnorB(Tzl«)<l.  Dillarent  values  ol  gaoBa 
Bust  be  absorbed  into  the  appropriate  rovs  ol  the  plant  Batrix. 

Inputs: 

Method  ol  evaluating  generalized  nixed  h2/hinl  cost  lunction  can  be  selected: 
l*l(trac*),  2(Bax  eigenvalue),  or  3(Bax  diag  eleaent) 


Systen  natrix  ’pd’ 
dinensions: 

Bust  be 

a  packed 

Bu-tools  systoB  natrix, vith  the  noted 

Dind) 

DiaO) 

DiB(2) 

p  -  1  AA 

1  B1 

B2  1 

1  CO 

1  DOl 

D02  1 

1 

1  Cl 

1  Dll 

D12  1 

1  Din(4) 

1  C2 

1  D21 

D22  1 

1  Din(5) 

Note:  the  coluans 

and  rovs 

associated  vith  the  input  v  and  the  output  zl 

Bust  have  been  scaled  lor  gaBBa«l 
*nltr'  ia  the  nax  nuaber  ol  iterations 
’exit’  is  the  exit  criteria  as  Iraction  ol  the  cost 


Outputs: 

K-  dynanic  controller  in  packed  (autools)  lorn 
count-  iteration  breakdown  on  ellipsoidal  routine 
Psil,Psi2-  upper/lower  bounds  lor  nixed  cost 


y,  dh2inloplb  calls  dliric2,  row,  col  (personal  codes)  and  unpek  Iron  nu-tools 
y.  toolbox  as  well  as  d2hinlsyn  and  its  subroutines 
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y.  unpack  ayatan  aiatricaa 
CAA,B,C,0]>ttnpck(p); 

natataa«DiB(l) ;  qcontrolBDiBi(2) ;  pdiatBDiaiO) ; 

routput«DiB(4) ;  BOUtputBDiB(S) ; 

nout0«ro«(C)-routput-BOUtput ;  pqBDiB(2)'»’pdiat ; 

tt>ro«(D)-BOUtput ; 

B1«B( : ,  1  rpdlat) ;  B2<bB(  :  .pdiat'fl  :pq) ; 

C0«C(1  :noutO, : ) ;  C1*C(  (noutO‘t’1)  :nontO‘t'routput , : ) ; 

C2>C(  (noutO't-routput-t'l)  ;roH(C) , : ) ; 

DO 1 O ( 1 : noutO , 1 : pdiat ) ; 

D110((tt-routpat'fi)  :tt .  1 :  pdiat ) ; 

D21aD((nout04’routput‘«’l)  :rov(C) ,  l:pdiat) ; 

D02«D(1 : (tt-routput) ,pdiat«l  :pq) ; 

D120((tt-routput-*'l)  :tt,pdiat41:pq) ; 

D22*D((nottt04'routput4^1)  :ro«(C)  ,pdiat'»l  :pq): 


gaB»l: 

Ia*aya(Dll*Dll>)*Dll*Dll‘; 

y.  aolva  tha  flltaring  aquation 

[U,L2.q.qarror.arngl]>dfiric2(AA*.Cl',C2>.Bl‘.Dll\D21'  .g«)! 
if  arflgloi, 

y.  Build  Gfi(q),  tha  augBantad  plant 

V»C2*q*C2'*D2iaD21*s 

R«Ia-Cl*q*Cl • fciaqacq • • ( V\C2*q*Cl * ) ; 

2»AA*q*Ci**Bl*Dll*-(AAaq*C2»+Bl*D21')*{V\(C2*q*Cl '+021*011  •)): 

Vhalf >inv(aqrtB(V) ) ; 

Rbalf >inT(aqrtB(R} ) : 

AAq*AA+Z*(R\Cl): 

Blq>(AA*q*C2'+Bl*D21'+Z*(R\(Cl*q*C2'+Dll*D21')))*Vhalf ; 

B2q>B2+Z*(R\D12): 

DO Iq- (001*02 1 ’+C0*q*C2’ )*Vhalf ; 

ClqvRhalf *C1 ; 

01 lq«Rhalf * (Cl*q*C2 '+011*021') *Vhalf ; 

D12q*Rhalf*012; 

pqspck(AAq,  [Blq,B2q]  ,  [CO ;Clq]  ,  [D01q.D02;Dllq,D12q] ) ; 

y.  coBputa  tha  f  iltaring  coat 
Sf >C0*q*C0+D01*D01 '-D01q*D01q; 

%  Boa  aolva  for  tha  full-info  gaina  which  aatiafy  tha  hint  prob 
[Kfi,Kp,X,E, count, Pail, Pai2,outcoBa,tiBa]  ■dh2infayBl(f ,pq,DlB,Sf ,Bitr,azit) 

XlsKfK:  ,l:natataa) ;  K2>Kfi(:  ,natataa+l:natataa+pdiat) ; 

alaa, 

azTorC 'Filtaring  aquation  infaaaibla') 


1G6 


return 


end 

'/.  Build  controller 
Ac«AAq-)-B2q*Kl-(Blq-i-B2q*K2)«Vhalf*C2: 

Bc«(BlqfB2q*K2)*Vhnlf; 

Cc«Kl-K2eVhnlf*C2: 

Dc>K2*Vhalf ; 
k^pek ( Ac , Be , Cc , Dc ) ; 

V.  end  d2hinlsyn 

D.  Validation  of  the  Ellipsoidal  Codes 

While  the  ellipsoidal  algorithm  itself  is  very  simple,  the  complexity  of  the  deriva¬ 
tion  of  the  gradients  and  their  translation  into  code  was  a  fertile  ground  for  mistakes. 
Means  were  consequently  required  to  validate  the  results.  Two  methods  were  used  to 
test  their  validity.  First  of  all,  Rotea  presents  results  for  an  example  problem  in  [Ref. 
29]  where  an  ellipsoidal  algorithm  was  used  to  determine  a  measurement-feedback 
controller  by  soliving  the  generalized  synthesis  problem  .  In  coding  the  gener¬ 
alized  mixed  7^2  /Hi  problem,  a  generalized  'H2  algorithm  was  first  written.  These 
results  matched  Rotea’s  data  exactly.  This  code  was  then  modified  slightly  to 
accomodate  the  Hoo  constraint.  Testing  the  satisfaction  of  this  constraint  on  the 
final  output  was  built  directly  into  the  termination  criteria  for  the  code.  Secondly, 
each  gradient  subroutine  was  verified  by  calculating  the  gradient  at  multiple  random 
points  in  the  search  space  both  u.sing  the  subroutine  and  by  a  brute  force  differencing 
method.  This  comparison  was  very  successfjl  in  finding  errors  in  either  the  coding 
or  in  the  original  derivations. 
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APPENDIX  BrCONTROLLER  DESIGN 
EXAMPLE  SCRIPTS 


This  appendix  documents  the  MATLAB  scripts  and  simulink  models  that  were 
used  for  the  design  and  analysis  of  the  autoland  controllers  in  Chapter  IV,  The  model 
used  for  both  controllers  was  identical,  and  a  single  script  prepared  both  synthesis 
models  in  order  to  ensure  that  the  designs  were  for  identical  systems.  Consequently 
several  of  the  sections  pertain  to  both  designs.  The  first  section  presents  the  simulink 
models  and  the  equation  of  motion  function  file  from  which  the  linearized  models 
were  extracted  and  which  were  used  during  the  analysis.  It  also  includes  the  scripts 
which  established  the  linear  synthesis  models.  The  second  section  includes  the  scripts 
used  to  perform  the  state-feedback  and  measurement-feedback  design  for  the  Tfco 
controller.  The  third  section  includes  the  scripts  which  were  used  to  design  the  mixed 
“Hi  /  controller, 

A.  NONLINEAR  MODELS 
1.  Equation  of  Motion 

The  following  equation  of  motion  script  was  used  at  the  core  of  all  the 
nonlinear  models  to  perform  the  calculation  of  the  state  derivatives.  Since  the  F- 
14  design  problems  were  limited  to  longitudinal  axis  glideslope  tracking  problems, 
only  the  longitudinal  states  are  considered.  The  requirement  to  perform  robustness 
analysis  and  design  also  required  the  inclusion  of  uncertainty  inputs  and  outputs 
in  the  equations  of  motion.  These  terms  are  reflected  in  the  variables  delta.in 
and  delta.out.  The  stability  derivative  data  was  extracted  from  [Ref.  48]  for  a 


flight  condition  of  134  KIAS  and  11.7  degrees  in  the  power  approach  configuration. 
Because  the  control  power  derivatives  for  the  DLC  were  unavailable,  it  was  scaled 
to  produce  0.1^  of  vertical  acceleration,  and  O.Olt/  of  horizontal  deceleration  at  a 
deflection  of  0.5  rad.  True  states  were  calculated  internal  to  the  equations  of  motion, 
and  perturbation  states  were  therefore  integrated  exterior  to  the  equations  of  motions. 
This  architecture  simplified  simulation  and  trimming,  since  all  signals  external  to  the 
equations  of  motions  were  perturbation  states.  The  trimmed  lift  and  drag  coefficients 
were  adjusted  from  their  handbook  values  because  they  were  slightly  inconsistent 
with  the  values  necessary  to  trim  the  model  at  the  specified  thrust  and  weight. 
eom4 


function  statodot>«OB4(stat«) 

V,  datominaa  eontinuoua  tlna  atata  darivativa  for  nonlinaar  longitudinal 
y.  aquationa  of  Motion. 

y.  Thia  varaion  all  atataa  raad  in  ara  tha  parturbation  atataa 

y,  flight  condition: 
g=32.174: 
a-54000/g; 

Iyys247194; 

Sb566  ; 
cbar<:9 . 8 ; 
alphaT-0 ; 
zT»0; 

VO- 134* 1.6889; 
rho>. 002376; 
alpha0«l 1.4/87. 3; 
thataOsalphaO; 

T0=13118; 

y,  F-14  darivativaa 
CDtsO. 37406269;  %  triaunad  coafficianta  (thaaa  diffar  from  handbook) 

CLt*l. 49634913; 

CmtsO; 

CDU«0; 

CLU*0; 

CMU«0; 

CDA*0. 0208*67. 3;  %  rad'-l 

CLA*0. 0799*67. 3;  %  rad‘-l 


y.  fpa 
y.  aluga 
y,  alug-ff2 

y.  ft -2 
y.  ft 

*/,  thruat  incidanca  (radiana) 
y.  thruat  coupla 
y.  fpa 

y,  alug/ft‘3 
V,  rad 

y.  rad  -  trim  point  ia  laval  flight 
y.  Iba 
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CMA*-0.0116*67.3;  %  rad"-! 

CDq«0; 

CLQ«5.46;  %  rad‘-l 

CMg»-14.3;  %  rad*-l 

CDAD«0; 

CLAD*-0.61:  %  rad‘-l 

CMAD«-0.93;  %  rad‘-l 

CDIS>0; 

CLIS>0. 0141*67. 3;  X  rad‘-l 

CMIS»-0. 0201*67. 3;  X  rad‘-l 


X  tha  DLC  control  power  la  aealod  to  parait  .Ig  at  lull  daflaction  of  .6  radiant 
CLDLC*0.1*CLt/(0.6); 

CDDLC>0. 1*CLDLC: 

CNDLC«0; 

X  Unpack  perturbation  ttatat 
du«ttata(l) : 
dalphasttata(2) ; 
qsatata(3) ; 
dthata*ttata(4) ; 

Btab«atata(6) ;  X  Theta  are  perturbation  deflectiona 

dT*atata(6): 

DLC«atate(7) ;  X  ditto 

delta_in>Catate(8);atate(9):atate(10)] ; 

X  Calculate  true  atatea 
u«(du*cet(alphaO))*VO; 
alpha«dalpha*alphaO ; 
theta«dtheta*thetaO ; 

T*T0+dT; 

X  Calculate  the  djnaaic  pretture 
Vsu/coa(alpha) ; 

Q=0.6*rho*V2; 

X  following  aatriz  incorporatea  both  fired  conatanta  and  rotation  fron  atab 
X  aria  to  body  aria 

Rwb«[-coB(alpha}  aia(alpha)  0;-ain(alpha)  -coa(alpha)  0;0  0  1]; 

Rbw«llwb' ; 

QTsQ*S* [-COB (alpha)  ain(alpha)  0;>ain(alpha)  -coB(alpha)  0;0  0  ebar] ; 

X  LHS  coapriaea  aaaa  aatriz  and  alphadot  aero  forcea 
LHS«diag([a*V0.a*V,Iyy])-QT*(cbar/2/V)*CCDAD  CUD  CNAD]‘*[0  1  0]; 

X  Deteraine  coupling  tera  (body  area) 

Fconple>a*q*[-ain(alpha)*V;  u;  0]; 

X  Deteraine  gravity  tern  (body  area) 

Fgrav>a*g*C-ain(theta):  eoa(theta);  0]; 
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'/.  D«t«rnin«  thrust  tsn  (body  arts) 

Fthrust«To[cos(slphaT) ;  slnCalphaT);  zT]  ; 

Build  asro  forcss  in  stability  axss  and  than  rotata  to  body  axas 
Tri««[CDt;  CLt;  0]; 

Dorv»[CDUaV0  CDA  CDQ;  CLU*V0  CLA  CLQ;  CNUaVO  CMA  CNQ] ; 

CPo«ar«CCDIS  CDDLC;  CLIS  CLDLC;  CNIS  CNDLC] ; 

FaaroBQT*(TriM-<-Darva[du;dalpha;q*cbar/2/V]‘fCPo«ar*[stab;  DLC]'f  dalta.in) ; 
dolta_outsDarvaCdu:dalphaiqacbar/2/V]-t'CPoHara[stab;  DLC] ; 

8tatadotl«LHS\(Fcoupla-t'Fgrav-t'Fthrust-«-Faaro) ; 

thotadot«q; 

gaamaBthata-alpha; 

Hdot « St at adot 1 ( 2 ) * V ; 

hdot«sin(gaBna)av/VO;  %  lota  that  hdot  is  scalad  by  valocity 

8tatadot*Cstatadotl:thatadot:  hdot;  udot;  V;dalta_out] ; 
y.  and  aom4 

2.  Openloop  Simulink  Model 

The  open-loop  simulink  model  from  which  the  synthesis  model  was  ex¬ 
tracted  is  presented  in  Figures  B.l,  D.2,  and  B.3.  The  model  includes  the  actuator 
models,  as  well  as  the  appended  integrators  on  the  outputs  of  interest.  As  discussed 
in  Chapter  IV,  additional  integrators  were  recjuired  midway  through  the  design  pro¬ 
cess  in  order  to  achieve  the  desired  tracking  properties.  These  figures  include  the 
additional  appended  integrators.  These  models  were  not  used  for  any  simulation,  but 
represented  a  graphical  means  of  accounting  for  the  paths  of  various  signals  through 
the  system. 

3.  Synthesis  Model  Construction 

The  following  script  performed  the  function  of  extracting  the  linear  model 
and  creating  the  state-space  formulations  for  both  the  HfX)  controller  design  and  the 
mixed  design.  Beyond  the  linearization  itself,  the  principal  piirpo.se  of  this  script  was 
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o 


Figure  B.l:  Open-Loop  SimuHnk  Model 
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nonlinear  plant  +  actuators 


Figure  B.2:  Non*Linear  Plant  and  Actuators  Block 

to  perform  the  necessary  bookkeeping  functions  of  collecting  the  appropriate  channels 
into  the  appropriate  inputs  and  outputs  of  the  vectors  w,  Zo,  ^l ,  and  y.  Finally,  some 
baseline  scaling  of  the  input  and  output  signals  was  performed.  The  system  matrices 
were  then  compiled  in  a  /<-tools  system  matrix  format  [Ref.  24]  to  be  passed  to  the 
appropriate  design  codes, 
plant 10c 


'/.  Establish  synthssis  plant  for  aizad  controllar  and  binf  dasign  problsn 
y.  This  usss  tho  fl4  nodal  axtractad  fron  fl4nlaaro6 
y.  This  problan  is  a  glidaslopa  trackar  with 
*/•  with  doubla  intagrators  on  DLC  and  alpha 

Daltas0.2aaya(3) ; 

taul>0.4;  %  povar  plant  tina  constant  (2.5  rad/s) 

tau2s0.06;  7.  horizontal  stab  tina  constant  <20  rad/s) 

tau3>0.02;  7.  DLC  tina  constant  (60  rad/s) 

s  igna_gan>3/67 . 3 ;  7«rad 
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Figure  B.3:  Output  Integrators  Block 


U0«t34*l.d889: 

CAA,BI,CC,DD]BliiUiod(  'f  14nl««ro5') : 
y,  lliuod  ord«r*  ststMCld): 

y.  b_«r/f2 ,  alph««r/a2 ,  DLC/i2  ,u ,  alpha ,  q  ,tbata ,  itab ,  T  ,DLC ,  b ,  alp_«r/t  .b_tr/s  ,DLC/b 

y.  inputs: (21) 

y.  b_c«d,alp_cad,DLC_cad,13  nois«s,stabc,Tc,DLCc,dal  1-3 
y.  outputs: (18) 

y,  h_sr/s2, alpsr/s,DCL/s,hdot,h, alpha, q.thsta, lx. (lz-1) ,V,DLC, 
y,  stabcMul,TcBid,DLCcBd,doll-3 

y,  Rsquirss  plant  bs  input  in  fora: 

y. 

y.  xdot*  AA*x  +  Bl*w  4’  B2*u 

y.  z0«  C0*x  4-  002*U 

y.  Zl*  C1*Z  4  4’  D12*u 

y.  y*  C2*x  4  D21*w 


y.  *a’  rsprssants  tbs  full  output  fasdbaek  plant 

y.  'b*  is  rsducod  statsfssdback  plant  (noiss  coluans  strippad) 
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Bla=BB(:,[l:lS, 19:21]); 


Blb>BB(:, [1:3. 19:21]); 


B2«BB(: .16:18); 


•/,  Pur*  Hinl  Plant  natrice*  •*♦******••*•••***♦**♦♦•♦* 

'/.  Importut:  dalta  sealed  by  factor  of  .2  already 

'/,  z  1 :  h_*r/s .  alper/s , DCL/s , stabcad . Tesd . DLCead. udot .  alpbadot , qdot . thetadot . hdot . 
y.  d*ll-3  (14) 

Cla«[CC([l:3. 13:16],:);  AA(C4:7. 11] . :) ;  CC(16: 18. : )]  ; 

Dllasz*ros(14.18);  Dllb«z*roa(14.6) ; 

D12a>[DD([l:3,13:16],16:18);  B2([4:7.11]  . : ) ;  DD(16:18, 16:18)]  ; 

'/i  y:  h_*r/s2.alp*r/s2,DCL/s2,h,alpha.q.theta.Mx.(lz-l)  ,V  (10) 
C2«CC([1:3,8:11],:); 

021«DD([1:3.6:11].[1:16.19:21]);  D22*DD([1:3.6:11] ,16:18); 

y.  Pack  mixed  output  feedback  plant 

pnom. a>pck(AA,  [Bla  B2]  ,  CCla;C2]  ,  [Dlla,D12a;021,D22] ) ; 

y.  Pack  atatefeedback  plant 

pnon. b*pck(AA, [Bib  B2] ,Cla, [Dllb  D12a] ) ; 

y.  To  scale  outputs  for  hinf:  zl-  rovs  14:27 


y,  del  are  rows  25:27,  and  col  29:31 

•/,  e*******************  Build  Nixed  Plant  matrices  ***•*••*•••*•* 


y«  Important:  delta  sealed  by  factor  of  .2  already 

y,  zO :  h.er/s , alper/s , DCL/s , stabemd , Tend , DLCcnd, udot ,  alpbadot , qdot , thetadot , hdot  (11) 
C0«[CC([1:3,13:15],:);  AA([4:7, 11] . :)] ; 

D01c«z*ros( 11 , 18) ;  D01d«z*ros(ll ,6) ; 

D02«[DD([1;3,13:16]  ,16:18);  B2(  [4:7,11] ,:)]  ; 

y.  zl:  h_*r/s, alper/s, DCL/s, stabemd, Tend, DLCcmd,d*ll-3  (9) 

C1*CC([1:3, 13:18],:); 

Dllc>z*ros(9,18) ;  Dlld«zsros(9,6) ; 

D12>DD([1:3, 13:18], 18:18); 

y.  Pack  nixed  output  feedback  plant 

pnon_c*pck(AA,  [Bla  B2]  ,  [C0;C1;C2]  ,  [DOlc  D02;Dllc,D12;D21,D22]) ; 
y.  Pack  atatefeedback  plant 

pno!ii_d«pck(AA,  [Bib  B2]  ,  [C0;C1]  ,  [DOld  D02;Dlld,D12] ) ; 

y.  To  scale  mixed  outputs:  zO-  rovs  16:25;  zl-  rows  26:34 
y.  To  scale  Inputs:  noise  cols  18:29 

y.  Scale  Nominal  Nixed  Plants: 

Scalel>diag(  [0.001, 0.001, 0.001, 0.001, 0.000001,0. 001, 2*on*s(l, 3)]); 
pnom_c(26 : 34 , : ) «Scalslspnon_c(26 : 34 , : ) ; 
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pnoB_d  (26:34,:)«Scal«l  *pnoB_d  (26:34,:); 
'/.  Seal*  0 

pnoa_c(:  ,16: 17)s0.01*paoB_c(:  ,16:17); 
pnom_d(:  ,16:17)>0.01*pnoB_d(:  ,16:17); 

■dol*14*16/2-i-3*14; 

Diad*[14  3  6  9  sdol]  ; 

Dime*  [14  3  18  9  10  sdof  ]  ; 

S<s2«roa(row(C0) ) ; 

y,  and  plant  10c 


4.  Closed-Loop  Analysis  Models 

Figure  B.4  depicts  the  simulink  model  used  both  for  the  nonlinear  simula¬ 
tion  and  the  robustness  analysis.  A  V  implementation  of  the  various  controllers  W2is 
used  and  can  be  observed  in  Figures  B.5  and  B.6,  where  the  mefisurement  channels 
are  differentiated  prior  to  the  controller,  and  then  the  output  of  the  controller  passes 
through  double  integrators. 

B.  Woo  DESIGN  SCRIPTS 

The  follov/ing  scripts  performed  the  Woo  design  process  including  the  appropri¬ 
ate  scaling  of  the  weighting  functions,  calling  the  design  code  itself,  and  then  analyzing 
the  resulting  system.  The  two  subroutines  sfbanalS  and  snsrloop  performed  the 
analysis  of  the  state-feedback  system  and  the  analysis  of  the  sensor  responses. 
loopshapeS 

y.  Control  Design  and  analysis  for  plsntlOc 

y,  PlsntlOc  is  sztractad  froa  fl4nlaoro6.  Includes  double  integrators 

y,  on  altitude,  alpha,  and  OLC  to  track  altitude  and  washout  alpha  and  DLC  in 

y.  response  to  a  rasp  altitude  input. 

y.  Broken.loop  analysis  for  output  feedback 

y. 

y,  Detemines  pure  hinf  dynaaic  controller 


176 


Figure  B.4:  Closed-Loop  Simulink  Model 


177 


y1>hdal,h,dbhM.lM. 


V.DLC 


Figure  B.6:  Output  Integrator  Block 
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%  Plots  brkloop  control  rosponss  vs.  sfb  dosign 
X  Plots  clsdloop  coHsand  rosponss 
'/.  Plots  clsd  loop  sonsor  rosponss 
plsntlOc 

V.  sfb  problon  voights--  [2  2.16110S65100  0] 
slbsnsl5.  Ksfb>X; 
y.  opfb  problon  voights 

%Cp2o,pl]>scslol6(pnon_n,pnon_b,  C2  6.5S1S0655  .100  0]); 
[p2o,pl]«scalol6(pnon_n.pnoB_b, ClO  30  5  5  .  01  1  0  10  6  1  0  0  0  0]); 

distscslo- [1.1,1,. 00001* C.l  4  4  0  .01  .01  .01  .1  10  10  1  0  6  6  6]]; 
p2>p2o;  p2(:  ,16:32)>p2o(:  ,lS:32)*disg(distscalo) ; 

y.  cnlculato  hinf  opfb  eontrollor 
K  «  hiufsyn(p2. 10,3,0,60000.600): 

[Ac , Be , Cc , Dc] Bunpek (K ) ; 

AAcl«[AA  B2*Cc;Be«C2  Ae*Be*D22*Ce] ; 

snsrloop4 

Batar>[B2:aoros(sl<o(B2))] ; 

Cstar>[soros(sico(Ce)),Ce] ; 

W«logspaco(-3,3,100) ; 


y. 

y.  brokon  loop  controller  rosponss 

y. 


KasCc;  Ka(l,:)"soros(l,14); 

Tual«pck([AA,B2*Ka:Bc*C2,Ac*Bc*D22*Cc]  ,Bstar(:  ,1)  ,Cstar(l , : )  ,0); 
BrkLoopl>frsp(Tuul , V) ; 

Xb*Cc;  Kb(2,:)«zoros(1.14): 

Tuu2*pck([AA,B2*Kb:Bc*C2,Ac*Bc*D22*Cc]  .Bstar(:  ,2),Cstar(2, : ) ,0) ; 
BrkLoop2sfrsp(Tuu2.W) ; 

XcbCc;  Xc(3, :)Bzoros(l,14); 

Tuu3«pck( [AA,B2*Xc ;Bc*C2, Ac]  ,Bstar( :  ,3)  ,Cstar(3, : )  ,0) ; 

BrkLoop3«frsp(Tuu3,V) ; 

figuro(7) , 

vplot(*liv,ln'  .BrkLoopl,  ’r-’  ,BrkLoop2, *g — ' ,BrkLoop3,  *b-.  *  .sfbloops,  'yO.grid 
title  ('Brokon  Loop  Controller'), 

f iguro(8) ,vplot( 'nyq'  .BrkLoopl,  'r-'  ,BrkLoop2, 'g — *  ,BrkLoop3,  'b-. '  .sfbloops, 'y' ) , 

grid,  titloCXyquist  Plot'), 

axis([-6  6  -6  6]  ),  axis  ('sqnaro'),  axis  ('equal'). 
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•/. 

V.  Op«n  Loop  controllor  rooponso 

y. 


Kcsz«ros(3,12) ; 

Tuu4*pck  (  CAA  ,  zoroB  ( 14 , 14 ) ;  Be*C2 ,  Ac] ,  Bttur  .Citar ,  zeros  (3,3)); 

0p«nloopsvBvd(lrsp(Tua4 , V) ) ; 

ligurB(9) ,vplot( 'liv.lB* ,OpBaloop),grid, 

titlsC ’Open-loop  Controller  Reeponee*) 

y.  Closed  loop  coBBsand  response 
BinsCBB(: ,1:3) ;seros(14,3)] ; 

Cottt-[CC([6:6,12].:),Cseros(2,14);DD(12,16:18)*Cc]]; 

Cout2«  [CC (  [6 : 8 , 13 : 16]  , : ) , DD(  [6 : 8 , 13 : 16] ,  16 : 18) tCc]  ; 

Thh«pck(AAel,Bin( : , 1) ,Cont(l , : ) ,0) ; 

Tvv«pek(AAel,Bln(: ,2) ,Coat(2, : ) ,0) ; 

Ttt>pck(AAcl,Bin(: ,3),Cont(3, :),0): 

ClooplalrBp(Thh,U) : 

Cloop2Bfrsp(Tvv,V) ; 

Cloop3«frsp(Ttt ,U) ; 

figure(lO), 

vplot( 'liv,lBi*  .Cloopl,  'r '  ,Cloop2,  ’g’  ,Cloop3,  ’b*  ,slbcadloop,  'e*  ,dB3thres,  '■’) , 
title( 'Closed  Loop  Cosstend  Responses’), 

X  Closed-loop  eigenvalues 
[V,E]«eig(AAcl):  E-diag(E): 

disp( ’Closed  Loop  eigenvalues  and  danping  ratios’) 

[E,-coB(angle(E))] 

y.  Open  Loop  eigenvalues  and  controller  zeros 
disp( ’Open-Loop  Poles’) 

El»eig(AA) 

disp( ’Controller  Zeros’) 

Kzerootz (Ac,Bc,Cc,Dc) 


y. 

y,  nu  analysis  of  the  closed-loop  systeas 

y. 


dispCdo  you  want  to  do  the  siu  analysis?’) 

dispC’Type  qq*0,  folloved  by  return  to  stop,  else  type  return’) 

qq*i: 

keyboard 

if  qq**0,  return,  end 
UBlogspace(-2,3) ; 
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'/•  tlb  BU 

Aafb*(AA-t'B2*Ktfb): 

Td«l>pck(Atlb.BB(:.  10:21). CC(ie:18.:}. 00(16:18. 19:21));  TdalrfpefrapCTdal.V) ; 
NuTsfb>Bu(Td«lr«p. Cl  1:1  1:1  1]): 

X  oplb  Bu 
00-134*1.6889; 

D«lta«0.2*«y«(3): 

[Ad.  Bd ,  Cd.Dd]  slinBodC  lAnlclsdS  * ) ; 
Tdal2>pck(Ad.Bd(:.16:18).Cd(16:18.:).0d(16:18.16:18)); 

Tdal2rapslrsp(Td«12.W) ; 

MuToplb«Btt(Td«12rip ,Cl  1:1  1;1  1]): 
figur«(ll).vplot('liv,lB'  .NuTafb.  .MuToplb.  • — *). 

X  titlaCStructurad  Singular  Valuaa'). 
grid 


sfbanal5 

X  Scale  output  vector  zl 

X  Cp2.pl]«acalel6(pnon_a.pnoB_b.  [2  2.1S11056S100  0]); 
Cp2.pl]«acalel6(pnoB_a.pnon_b.  [10  30  S  S  .01  1  0  10  8  1  0  0  0  0] ) ; 

X  zero  out  uncertainty  coluana 
pl(: .17: 10)>zeroa(aize(pl(: ,17:19))); 

X  Analyaia  of  abate  feedback  control  ayatea 
K  «  hinffKpl. 3, 0.60000, 1000); 

nn  s80; 

W*logapace(-3,3,nn) ; 

K*K(:.l:14); 

X  broken  loop  controller  reaponae 

Ka«K:  Ka(l, :  )«zeroa(l,14) ; 

Tuul>pck(AA'fB2*Xa,B2( :  ,1)  ,K(1 , : )  ,0) ; 

BrkLoopl*frap(Tuul ,V) ; 

Kb>K;  Xb(2,:)*zaroa(l,14); 

Tuu2-pck(AA*B2*Xb.B2( : .2) .X(2, : )  ,0) ; 

BrkLoop2«frap(Tuu2,V) ; 

Xc«X;  Xc(3, : )«zeroa(l,14) ; 

Tuu3>pck(AA*B2*Xe,B2( : ,3) ,X(3. : )  ,0) ; 

BrkLoop3«frap(Tuu3,V) ; 

afbloopa*[BrkLoopl(l  :nn,  1)  ,BrkLoop2(l:nn.l)  ,BrkLoop3(l:nn,  1)] ; 
afbloopa«vpck(afbloop8,getiv(BrkLoopl) ) ; 
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ligura(l),vplot('liv,]ji'  .BrkLoopl.  *r-*,BrkL.'>r'p2,  'g--'  ,BrMLoop3,  'b-.  ’) 

'Broken  Loop  Controllor  B«iponto'),grii 
ligoroO)  .vplot( 'nyq'  .BrkLoopl,  'r-' ,BrkLoop2,  'g— ’  .BrkLoopS,  'b-.  • ) , 
nxis([-5  6  -6  5]), grid 

*/,  cloiod  loop  coMMBd  rosponso 

Thb*pck(AA«B2*X,Blb( : .1) .CC(6. : )4DD(S.16:18)*K.DD(5.1)) ; 

CladLoop4>fr*p(Thh,V) ; 

Tvv«pck(AA+B2*K,Blb( : .2) .CC(6. : )-fDD(e.l6: 18)*K,DD(6.2)) ; 

ClsdLoop5>lrsp(TvT,V) ; 

Ttt«pck(AA4B2*X.Blb(:.3),CC(12,:)-*^DD(12.18:18)*K,DD(12.3)); 

ClidLoop6>lrsp(Ttt.V) ; 

■Ibeadloopo  [ClsdLoop4(l :  nn ,  1 ) ,  Cl*dLoop6(  1  :nn,  1 ) ,  CltdLoop6(  1 :  nn ,  1 )] ; 
•fbcndloop>vpck(tlbcBdloop  ,gotiv(ClidLoop6) ) : 

dB3thrat«cos(pi/4)*on«s(iis«(W)) ; 

iigura(2).Tplot('llv.la'  .CladLoopd,  'r-' .CladLoopB,  'g— *  ,ClsdLoop6,  'b-.  ',dB3thraa,  'y: ') 
titlaC'Cloaad  Loop  Conand  Raaponaa').grid 


CV.E]>aig(AA+B2oX);  B-ding(E);  V>«ba(V): 
CE,-coa(«ngla(E))] 

return 


snsrloop4 

y.  Analyaia  of  the  aanaor  raaponsaa 
y.  Intended  for  call  by  loopahape  icript 

Blq*[zoros(size(Bc)):Bc] ; 
CCq«Czeros(aize(cr)),CC] ; 

VUslogspace (-8 ,5,100); 

%  cloead  loop  aanaor  reaponae 

anarl*pck(Ac ,Bc( : , 1) ,C2( 1 , : ) ,0)  ; 
SnarLoopl>frap(anarl ,\ni) ; 

anar2>pck(Ac,Bc( : ,2) ,C2(2, : ) ,0) ; 
SnarLoop2*frap(anar2,UU) ; 

anar3«pck(Ac,Bc( : ,3) ,C2(3, : ) ,0) ; 
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SnarLoop3*lrsp(sntr3,WV) ; 

insr4«pck(Ac,Bc( ; ,4) ,C2(4, : ) ,0) ; 

SnsrLoop4>lrsp(ansr4,W) ; 

sn>r6«pck(Ac,Bc(: ,6),C2(6, :) .0); 

SnsrLoopE*lrap(antr6tWV) ; 

anar6«pck(Ac,Bc( : ,6) ,C2(8, : ) ,0) ; 

SnarLoop0«lrap(anar6,WV) ; 

anar7spck(Ac,Bc( : .7) ,€2(7, : ) ,0) ; 

SnarLoop7*lrap(anar7|W) ; 

anar8«pck(Ac,Bc( : .8) ,02(8, : ) ,0) ; 

SnarLoop8>frap(anar8.VW) ; 

anar9«pc^  ‘.c,Bc(:  ,9).C2(9, :)  ,0); 

SnarLoopi  xrap(aBar9.W) ; 

anarlO«pck(Ac,Bc(: ,10),C2(10. : )  ,0); 

SRarLooplO*frap(anarlO,VW) ; 

figura(4).clg 

vplotCllv.lm*  ,SnarLoop7, ,SnarLoop8,  ‘  ,SnarLoop9,  *  .SnarLooplO,  *-')  .hold  on 
vplot(  'llv.la’  ,SnarLoop4,  'r-'  .SnarLoopS,  *g — *  .SnarLoopB,  'b>. ') 
vplotC  'liv.la*  .SnarLoopl ,  'r-'  ,SnarLoop2,  'g—*  .SnarLoopS,  'b- . ' ) 

ratnrn 


C.  MIXED  Kj  /  Woo  CONTROLLER  DESIGN  SCRIPTS 

The  script  in  this  section  was  used  to  design  the  mixed  controller  described  in 
Chapter  IV. 
msfbanal 


y,  Daaign  and  Analyaia  of  aixad  atnta-faadback  control  ajataa 

plant 10c 

p>pnoa_d; 

'/.acala  zO 

z0scala*[l, 10000, 1,1000,1, .1,0, 0.0, 0,0} ; 
p(15:25, : )«diag(z0acala)*p(16;26, ; ) ; 

CK,Kp,X,E,ct,Pl,P2,oc,t]«  h21nfayn(l,p,DiBd,Sf ,25000,0.01) ; 
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Kalb*K; 


nn  «80; 

W«logap\c«(-3,3,iui); 

'/.  broktn  loop  eontrollar  rocponio 

Ka«K;  Ka(l, :)>z«ro>(l,14); 

Tuul«pck(AA+B2«Ka.B2(:.l).K(l, :).0): 

BrkLoopl«lrsp(TQUl ,V) ; 

Kb*K:  Kb(2.:)«z«ros(1.14): 

Tuu2*pck(AA^B2*ICb.B2( :  .2) .X(2. : ) .0) ; 

BrkLoop2«frsp(Tuu2,V) ; 

Kc«K:  Xc(3,:)as«ro*(l,14): 

Tutt3>pek(AA*B2*Xe.B2( : .3) .X(3, : )  .0) ; 

BrkLoop3>frsp(Tau3,W) ; 

sf  bloopaa  CBrkLoopl  ( 1 :  nn  •  1 ) ,  BrkLoop2  ( 1 :  nn .  1 ) ,  BrkLoop3  ( 1 :  nn ,  1 )  ]  ; 
sf  bloopn*  vpek  ( af  bloopa ,  gat  Iv  (  BrkLoopl ) ) ; 

figura(l)|Vplot(  .BrkLoopl,  'r-*  ,BrkLoop2,  'g — '  .BrkLoop3,  'b-.  *) 

tltlaCBrokan  Loop  Controllar  Raaponaa*).grid 

flgura(3),vplot('nyq' .BrkLoopl,  'r-'  ,BrkLoop2,  'g— ' ,BrkLoop3,  'b>. ') . 
nxia(C-6  6  -6  5]). grid 

X  cloaad  loop  eoa«nnd  rasponaa 

Thh>pck(AA+B2*X.Blb(: ,1) ,CC(6, : )<»DD(6.16:18)*X.O); 

CladLoop4*<rap(Thli,V) ; 

Tvv>pck(AA>B2*K,Blb(:.2).CC(«.:)4'0D(6.16:18)*K,0); 

CladLoop6«frap(TTV,V) ; 

Ttt>pck ( AA*B2*X . Blb( : , 3 ) . CC( 12 . : ) -^DDC 12 . 18 : 18 ) *K . 0) ; 

CladLoop0>lrap(Ttt .V) ; 

af  bcndloop>  CCladLoop4  ( 1 :  nn ,  1 ) ,  CladLoopB  ( 1 :  nn ,  1 ) ,  CladLoop6  ( 1 :  nn ,  1)  ]  : 
af  bcBdloopavpek(8fbcndloop  ,gat  ivCCladLoopB)  ) ; 

dB3thraa>coa(pi/4)*onaa(iiza(V) ) ; 

fignra(2) ,vplot( 'liv.la*  .CladLoopd,  'r-*  .CladLoopS,  'g--'  .ClndLoopB,  'b-.  ’ ,dB3thraa,  *y ; ') 
titla( ’Cloaad  Loop  Comnnd  Raaponaa*),grid 

[V,E]>aig(AA+B2*X):  E«diag(E):  V-mba(V); 

[E,-coa(nngla(E))] 

raturn 

X  and  naf banal. ■ 
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APPENDIX  CiINTERIOR  POINT  CODES 


A.  GENERAL  REMARKS 

This  appendix  documents  the  )■  ’  <  point  codes  used  during  for  many  of  the 

example  problems  cited  in  the  body  tht^  report.  The  codes  and  their  structure  are 
briefly  described  followed  by  a  verbatim  listing  of  the  routines.  The  codes  are  followed 
by  comments  on  practical  issues  of  their  use.  The  original  codes  upon  which  these 
are  based  were  provided  by  Professor  Khargonekar  of  the  University  of  Michigan  and 
were  the  result  of  work  performed  by  Enrique  Bayens.  his  student.  The  algorithm 
follows  [Ref.  14]  as  outlined  in  Chapt..'r  11,  and  is  written  as  MATLAB  function  files. 

These  codes  are  problem  independent,  and  are  structured  to  solve  the  Eigenvalue 
Problem  (EVP),  or  the  more  general  Generalized  Eigenvalue  Problem  (GEVP).  Recall 
that  the  GEVP  has  the  form: 

Minimize:  A, 

XB{x)  —  A(x)  0  0 

Subject  to:  0  B(x)  0  >0, 

0  0  Cix)  . 

where  A(x)  =  i4o+E"=i  =  ^o+ELi  C'(x)  =  Co+Er=i  ^iCi.  The 

EVP  is  the  simplified  case  where  B(x)  =  I.  We  will  refer  to  the  .set  {Aq,  Ai,  . . . ,  A„} 
as  the  basis  for  the  affine  matrix  functional  A(x).  The  application  of  these  codes  to 
any  particular  problem  simply  requires  that  the  problem  be  posed  as  a  GEVP  and 
the  three  sets  of  bases  determined  and  stored. 

1.  Posing  a  Basis 

Two  important  structural  concepts  introduced  in  Bayens’  original  code 
provide  a  mechanism  for  passing  these  bases  to  the  interior  point  routines.  The  first 
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is  what  he  calls  an  “a-matrix”,  which  is  simply  an  accounting  method  for  storing  a 
basis  as  a  single  argument,  which  can  easily  be  passed  from  function  to  function  in 
MATLAB’s  workspace.  For  example  if  A(.r)  =  Ao+ZiLi  then  the  corresponding 
a-matrix  is  Aa=  [Ao,  For  many  control  problems,  these  matrices  can  be 

huge,  and  the  interior  point  methods  can  con.sequently  be  RAM  intensive.  In  many 
applications,  the  matrices  A{x)  and/or  C(.r)  may  have  structure.  That  is,  A(x)  or 
C(x)  may  themselves  be  comprised  of  diagonal  blocks  of  matrices.  In  this  case,  it  is 
advantageous  to  use  the  structure  to  reduce  the  computational  expense.  The  codes 
each  then  ask  for  a  structure  matrix  Sc,  which  defines  the  internal  structure  of  a  set 
of  basis  matrices  Ca.  The  number  of  rows  of  S  is  then  the  number  of  blocks  in  C{x). 
Each  row  has  two  scalar  values.  The  first  value  is  a  “1”  or  “0”,  and  signifies  whether 
the  associated  block  is  a  full  block,  or  is  itself  a  diagonal  matrix.  The  second  value  in 
that  row  defines  the  size  of  the  block,  i.e.,  the  number  of  rows  and  columns.  These 
bases  are  then  passed  to  the  interior  point  routines,  along  with  an  initial  feasible 
point  and  any  knowledge  of  the  internal  structure  of  A(.t)  or  C(x).  Note  that  for 
all  the  problems  actually  solved  in  this  report,  the  EVP  was  considered  and  so  the 
a-matrix  for  B{x)  was  Ba=  [7,  zeros],  with  sufficient  zeros  such  that  the  size  of  Ba 
was  identical  to  the  size  of  the  a-matrix  Aa. 

2.  Modifications  to  the  Original  Code 

The  codes  presented  here  are  structurally  Identical  to  the  originals,  but 
differ  substantially  in  execution.  The  architecture  of  the  inputs,  outputs  and  sub¬ 
routines  are  unchanged.  Most  of  the  changes  were  in  the  interest  of  either  numerical 
efficiency  or  accuracy.  Several  changes,  for  example,  took  advantage  of  the  structure 
of  many  LMI’s  to  reduce  the  number  of  multiplications  by  Idocks  of  zeros. 
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The  most  important  changes  dealt  with  the  way  in  which  matrix  divisions 
were  handled.  The  interior  point  codes  involve  frerpient  divisions  by  positive  definite 
matrices.  The  original  codes  extensively  used  MATLAB’s  inv  function.  Replace¬ 
ment  with  MATLAB's  matrix  division  notation  was  occasionally  satisfactory  and 
efficient,  as  MATLAB  4.0  first  attempts  division  by  Cholesky  factorization  for  any 
symmetric  matrix.  Many  of  the  divisions,  however,  involve  positive  definite  matrices 
which  are  very  badly  conditioned,  to  which  MATLAB  responds  with  a  warning  mes¬ 
sage.  This  is  to  be  expected  since  one  is  trying  to  force  an  LMI  to  the  boundary  only 
c  away  from  singularity.  At  the  suggestion  of  Professor  Laurent  El  Ghaoui  (ENSTA, 
Paris),  all  poorly  conditioned  divisions  were  executed  by  first  performing  an  eigen 
decomposition  of  the  positive  definite  denominator.  The  result  is  a  real  diagonal  ma¬ 
trix  of  eigenvalues  and  an  orthonormal  matrix  of  eigenvectors  (H~^L  —  f/A~'t/^L, 
where  H  =  UAU^).  Multiplying  by  orthonormal  matrices  and  then  division  of  each 
row  by  the  corresponding  scalar  eigenvalue  optimized  the  accuracy  of  the  process. 
Consequently  the  expression; 

HL*inv(H)*L; 
was  replaced  with: 

[UH,DH]-eig(H); 

L1«UH'*L; 

for  i>l :ord«r(H) , 

L2(i, :)«DH(i,i)\Ll(i, :) ; 

end 


HL«UH*L2; 


This  is  not  at  all  the  most  efficient  means  of  performing  the  division,  but  their  badly 
conditioned  nature  has  led  more  notable  researchers  to  choose  the  accuracy  implicit 
in  this  approach.  It  is  however  much  faster  than  allowing  MATLAB's  matrix  division 
function  to  wrestle  with  very  poorly  conditioned  divisions. 

3.  The  Principal  Code 

The  function  canteraS,  and  its  variations  is  the  top  level  program  that 
solves  the  EVP.  The  “3”  simply  identifies  the  code  as  being  the  third  variation  to 
Bayens’  original.  Three  variations  to  centersS  were  used.  The  first  centers3b  simply 
suppressed  workspace  printing.  The  next  centersSc  suppressed  workspace  printing 
and  included  the  structure  of  A  as  an  input  argument  (the  original  had  only  used  the 
structure  of  C),  Finally,  centersSd  restored  workspace  printing,  while  continuing  to 
permit  the  structure  of  both  A  and  C  to  be  passed. 

As  discussed  above,  contersS  is  not  problem  specific,  but  suitable  for 
solving  any  EVP.  As  input  arguments  it  requires  the  bases  (a-matrices)  associated 
with  the  three  EVP  matrix  functionals,  (A(ar),  j5,C'(T)));  a  matrix  which  defines  any 
internal  structure  of  the  problem;  and  feasible  initial  conditions  x  and  A  from  which 
to  start  the  search.  (Finding  a  good  initial  point  is  discussed  later  in  this  appendix). 
The  remaining  inputs  are  numerical  thresholds  and  adjustments.  Since  centersS 
is  not  problem  specific,  it  was  used  for  all  EVP's,  including  the  mixed  discrete  and 
continuous  problems,  and  the  plant  optimization  problems.  In  each  of  those  cases, 
scripts  were  written  which  prepare  the  a-matrices  appropriate  to  each  problem,  and 
determine  a  suitable  initial  conditions  before  calling  centorsS. 

As  written  by  Bayens,  the  original  centers  was  intended  to  solve  the  more 
general  GEVP,  but  a  bug  in  the  subroutine  a88ump2  led  me  to  close  the  path  such 
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that  only  constant  B  matrices  were  permitted.  Since  a  GEVP  solver  was  not  required 
during  this  work,  the  bug  was  not  isolated  or  corrected.  Little  work  should  be  required 
in  order  to  permit  the  code  to  solve  the  GEVP,  if  it  becomes  required. 

4.  The  Subroutines 

A  large  number  of  function  files  accompany  and  are  called  by  the  central 
function,  centersS.  Several  of  these  functions  could  be  regarded  as  administrative, 
and  are  used  to  manipulate  a-matrices.  They  are  useful  both  within  centersS, 
and  also  in  preparing  a-matrices  in  problem  specific  applications  prior  to  calling 
centersS.  The  functions  affin  and  getvec  use  the  a-matrix  (basis)  of  A  to  map 
back  and  forth  between  t  and  A(.t):  A(t)  =  afFin(/trt,.T)  and  x  —  getvecfAa,  Afx)). 
The  function  adiag  manipulated  a-matrices  of  D(x)  and  E{x)  to  find  the  a-matrix 
of  the  functional  F{x)  =  E^x)  ’  extensively  whenever  two 

LMI’s  were  jointly  imposed. 

The  following  set  of  functions  could  rightly  be  called  subroutines,  as  their 
use  is  restricted  to  calls  from  within  centersS.  The  functions  assumplb,  a8suinp2, 
and  as8ump3c  checked  the  necessary  assumptions  before  starting  the  method  of 
centers.  First,  assunplb  verified  that  the  initial  point  is  feasible.  Next,  a88ump2 
confirmed  that  B{x)  was  bounded  away  from  singular  for  the  GEVP.  It  currently 
not  called  by  centersS,  and  would  have  to  be  fixed  in  order  to  .solve  the  GEVP.  It 
is  included  here  for  completeness.  The  subroutine  a88unp3c  actually  performed 
the  first  iteration  of  the  search  for  a  analytical  center  in  order  to  determine  if  the 
problem  is  bounded.  If  this  first  iteration  converged,  then  the  problem  was  considered 
bounded.  The  majority  of  the  work  was  performed  by  the  subroutine  neanenSa, 
which  actually  performed  the  search  for  the  analytic  center  within  the  inner-loop  of 
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the  method  of  centers.  Within  its  loop,  it  in  turn  called  grad2b,  which  returned  the 
gradient  and  hessian  at  each  step  of  the  search. 

B.  PRACTICAL  ISSUES 

This  section  addresses  a  number  of  practical  issues  regarding  the  use  of  these 
codes.  The  first  of  these  comments  is  relevant  to  the  use  of  any  interior  point  codes 
for  the  solution  of  LMTs.  Subsequent  remarks  ])ertain  specifically  to  the  author's 
experience  in  the  use  of  this  particular  implementation. 

1.  Determining  a  Feasible  Initial  Point 

All  the  interior  point  methods  are  dependent  upon  initializing  the  optimiza¬ 
tion  with  and  in  the  feasible  set,  i.e.  >  0  and  In  fact, 

the  codes  iii  section  C  verified  this  requirement  prior  to  any  optimi'^ation  attempt. 
As  a  matter  of  practical  experience,  it  is  not  just  enough  to  initialize  the  algorithm 
at  any  feasible  point,  but  ideally  a  point  well  away  from  the  boundary  for  which  the 
problem  becomes  singular  (unfeasible).  Riccati  methods  are  a  very  poor  choice  for 
determining  a  feasible  initialization  point.  This  is  because  the  numerical  methods 
for  solving  the  Riccati  equation  must  generally  make  allowance  for  a  tiny  negative 
eigenvalue  in  an  otherwise  positive  definite  solution.  Even  a  very  tiny  negative  eigen¬ 
value  however  places  the  corresponding  vector  x  outside  boundary  function  of  the 
LMI  with  no  means  of  crossing  the  boundary.  One  method,  suggested  by  El  Ghaoui, 
is  to  perform  a  preparatory  optimization  by  setting  C(x)  =  1  >  0,  x  =  [0, . . .  ,0]^, 
and  minimizing  A  such  that  A/  -f  (^(x)  >  0.  For  the  original  problem  to  be  feasible, 
a  A  <  0  must  exist.  Furthermore,  by  minimizing  A  <  0  (finding  its  maximum  nega¬ 
tive  absolute  value),  the  “best”  feasible  value  of  x*®*  is  determined.  The  problem  of 
interest  can  then  be  initialized  with  x*®*  and  some  A^®1  >>  Amor(A(.T^®*). 
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A  modification  to  this  approach  was  routinely  used.  Specifically  C(x)  usu¬ 


ally  had  some  structure  such  as  C(a:)  = 


R(t) 


,  and  the  first  n  elements  of 


X  were  the  diagonal  elements  of  V.  In  this  case  the  preparatory  problem  was  posed  as 
minimize  A  such  that  A/  -I-  R(x)  >  0,  subject  to  y(x)  >  0,  This  problem  is  easily  fea¬ 
sibly  initialized  at  such  that  =  /  >  0,  and  with 

^(00)  >>  A„,a*(/2(xf“l).  Consequently,  the  solution  of  an  LMI  frequently  required  two 
passes  through  the  interior  point  algorithm;  the  first  to  determine  a  feasible  solution, 
and  the  second  to  determine  the  (sub)optimal  solution. 

2.  Practical  Observations 

The  following  observations  were  made  relative  to  this  specific  implementa¬ 
tion  of  the  interior  point  method. 


1.  Much  of  the  clamor  surrounding  interior  point  methods  is  due  to  their  reputed 
dramatic  increase  in  computational  speed  over  other  convex  methods.  This 
makes  intuitive  sense  in  that  the  method  does  not  spend  any  time  outside  of 
the  feasible  set,  while  we  found  it  common  for  90%  of  the  iterations  of  the  El¬ 
lipsoidal  methods  to  be  spent  i.solating  the  feasible  set.  In  practice,  we  found 
little  difference  in  speed  between  the  two  methods  on  small  problems.  I  am 
certain  this  is  because  of  the  choice  of  MATLAB  as  the  programming  language. 
MATLAB  was  chosen  because  that  was  language  of  the  original  codes  provided 
by  Khargonekar,  and  because  it  could  be  rapidly  implemented  for  the  desired 
problems.  Computational  speed  was  not  a.s  critical  as  speed  of  implementa¬ 
tion.  With  the  attention  the  interior  point  methods  have  received  in  the  past 
two  years,  translating  these  codes  to  a  faster  format  would  be  unadvisable,  as 
commercial  codes  are  sure  to  become  available  shortly. 
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2.  Mathematically,  the  interior  point  codes  are  guaranteed  to  stay  within  the  fea¬ 
sible  set  due  to  the  influence  of  the  boundary  function  [Ref.  15].  This  was  not 
our  practical  experience.  Two  factors  routinely  led  to  the  method  of  centers 
wandering  out  of  the  feasible  set.  First  of  all.  the  numerical  adjustment  6  de¬ 
termines  how  close  to  singular  the  search  for  an  analytical  center  is  initialized. 
Mathematically,  the  code  should  converge  for  all  9  6  [0,  Ij.  In  our  experience, 
values  much  less  than  0.1  resulted  in  the  path  of  centers  occasionally  jumping 
outside  the  feasible  set.  Secondly,  in  a  similar  vein,  the  method  should  work 
if  initialized  at  any  Again,  if  the  problem  was  initialized 

too  close  to  the  boundary  for  which  the  LMl  was  singular,  then  path  of  centers 
could  wander  infeasible  before  converging  to  a  optimum  value.  Consequently, 
A*®l  was  usually  chosen  well  clear  of  the  boundary,  on  the  order  of  0.1  or  1  greater 
Amoi(A(x^°l).  Fiii  thermore,  there  were  some  problem  geometries  for  which  the 
codes  were  inexplicably  unstable.  Traps  were  implemented  in  the  code  in  order 
to  rapidly  identify  divergence  from  the  feasible  set,  thereby  slowing  the  general 
execution  of  the  routines.  This  was  done  in  order  to  alert  the  researcher  to 
bad  output,  but  did  not  correct  the  problem.  The  source  of  these  difficulties 
is  unquestionably  the  inherently  ill-conditioned  nature  of  these  problems,  their 
very  intent  being  to  puch  the  problem  to  singularity.  Again,  the  advent  of  more 
robust  commercial  codes  would  hopefully  mitigate  these  sensitivities. 

C.  MATLAB  FUNCTION  FILES 

This  section  includes  a  listing  of  the  interior  point  optimization  code  centersS 
and  its  associated  subroutines. 
centers3 
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f unct  ion  Cxopt ,  luibdaopt ,  ttat ,  orr]  =c«nt«rs3  ( A ,  B ,  C ,  Sc ,  x ,  lambda ,  thata ,  prac ,  bound ) 
'/.  Function: 

'/.  [xopt ,  laabdaopt ,  atat ,  arr]  *cant  ara3(  A ,  B ,  C ,  Sc ,  x ,  lambda ,  thata ,  prac ,  bound) 

•/. 

'/.  Description: 

•/. 

%  This  function  solves  the  problem  of  minimiza  the  maximum  ganaralizad 
*/.  eigenvalue  of  the  pair  (A(z),B(x))  subject  to  a  constraint  C(x)>0. 
y,  A(x)  and  B(x)  are  a  (sjmmetric,  symetric-positive-definite)  pair  of 
y.  matrices  that  depend  affinely  on  a  vector-valued  variable  x. 

y. 

y.  Inputs: 

y. 

y.  A«[A0  A1 . An]. 

y.  B*CB0.S1 . Bn], 

y.  Cb[C0,C1,  . . .  ,Cn] ,  are  a-matrices,  that  is  arrays  of  matrices  that 
y.  represent  an  affin  matrix  expression  depending  of  a  vector  x. 
y.  Sc  is  a  matrix  representing  the  block  structure  of  the  restriction 
y.  C(x)>0.  Sc  has  2  columns  and  the  number  of  rows  equals  the  number 

y.  of  blocks  in  C(x).  The  first  column  contains  the  type  of  block 
y,  (type  0  diagonal  block,  type  1  full  block),  the  second  column  is 
y.  The  size  of  each  block.. 

y,  xa[xl,x2 . zn]  * ,  is  an  initial  feasible  vector. 

y.  lambda  is  an  initial  value  vhich  satisfies  laabda«B(x)-A(x)>0. 

y,  theta  is  a  parameter  with  0<theta<i.  Typical  values  are  close  to  0. 
y,  prec  is  the  precision  in  computing  the  optimun. 
y,  bound  is  a  limit  of  normCx)  to  detect  unboundness  of  the 
X  problem. 

y.  The  affin  matrix  functions  can  be  calculated  using  the  function  affin 
y,  A(x)*affin(A,x)«AO'»Al*xl'». .  .4Anexn, 
y,  B(x)>affin(B,z)>BO'*’Bl*xl't’. .  .-i-Bnexn, 
y,  C(x)>affin(C,z)«CO'*'Cl*zl-*'. .  .-fCnexn, 

y. 

y.  Outputs: 

y. 

y,  xopt  is  the  optimal  vector 

X  lambdaopt  is  the  maximum  generalized  eigenvalue 

X  stat  is  a  matrix  with  the  statistes  of  the  algorithm.  The  first  column 
X  contains  the  iteration  number,  the  second  the  number  of  le*ton_ll 
X  iterations,  and  the  third  a  bound  of  the  error  in  the  compute  of  the 
X  optimal  value  lambdaopt. 

X 

X  lecessary  assumptions  to  solve  the  problem: 

X 

X  (1)  The  initial  point  is  in  the  feasible  set. 

X  (2)  B  is  bounded  avay  from  singular  on  the  feasible  set,  and  ve  know 
X  fcnin  such  that  B(z)  >  bmin*! 

X  (3)  The  feasible  set  is  bounded. 

X  err  is  an  error  code.  If  err«l  the  initial  point  is  not  feasible,  if 
X  err>2  assumption  (2)  does  not  hold,  if  errs3  the  problem  is  unbounded, 

X  in  this  case  xopt  is  yet  a  feasible  point,  but  norm(xopt)  >•  boundd  + 
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•/,  nor«(x)). 

y. 

y.  Called  lunctiona: 

y. 

y.  ataumpl,  chacka  aasuaption  (1). 
y.  aaauap2,  chacka  aatuaption  (2). 

y.  aaaump3c,  chacka  aasiuaptlon  (3),  uaaa  aigan  diviaion  with  Haaalan 
y.  boundl,  cowputaa  a  bound  of  tha  diffaranca  batwaan  lanbda  and  tha  raal 
y«  nlninal  value 

y.  affin,  conpvtaa  an  affin  aatrix  function. 

y.  adiag,  conputaa  tha  a-aatrix  of  C(x)  share  C(x)sdiag[A(x)  ,B(x)]  . 
y.  naanaaSa,  Newton  algoritha  to  coaputa  an  analytic  cantor. (aigan  diviaion) 
'/i  grad2b  ratuma  barriar  gradiant  and  haaaian  (atructurad  varaion) 

y. 

y.  Aa  of  1530  on  10/12/03  thia  is  tha  boat  parfoming  coabination  so  far. 
y.  Diract  diviaion  by  hasaian  laada  to  anoraoua  incraaaa  in  eputiaa, 
y.  probably  bacauaa  aatlab  doaa  avd  division  whan  it  soas  an  ill- 
y.  conditionad  problaa. 


y. 

X  Chocking  assuaption  (1) 

y. 

dispCNathod  of  cantors.  Chocking  initial  point  ...*); 
arr«assuaplb(A,B,C.x.lanbda) ; 
if  sun(arr')<0 

disp( 'Error  in  cantors. a.  Infaasibla  initial  point'); 
ditp(arr) 
ratum; 
and 

y. 

y«  Checking  assuaption  (2) 

y. 

dispCNathod  of  cantors.  Chocking  if  B(x)  is  bounded  ...'); 
[nb,nb]ssiza(B) ; 

if  nax(nax(abs(B(:  ,ab'»l:nb))))*B0,  %is  B(x)  constant? 
bain>nin(aig(B(; ,l:ab)}); 
constantb«l ; 

also, 

y.  bnin«assuap2(A,B.C,x. bound):  X  I  THINK  THIS  PATH  HAS  A  BUG! 
disp( 'non-constant  b  is  currently  disabled') 
constantb*0 ; 
and 

if  bainoO 

diap( 'Error  in  cantors. a.  B(x)  is  not  bounded  away  of  zero'); 
arr*2;  return; 

and 

X 

X  Chocking  assuaption  (3) 

X 

dispC 'Method  of  cantors.  Chocking  if  restriction  is  bounded  ...'); 
Carr ,  x2 .  laBbda3 ,  Z ,  it2]  «assunp3c  (A ,  B ,  C ,  Sc ,  X ,  laabda ,  theta ,  bound) : 
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if  trrssa 

dlspC’Error  in  cmtars.a.  Th«  raatriction  it  unbounded *) : 
xoptBx2 ; 

luibdaopt>luibdt3 ; 
return; 

•nd 

y. 

%  Algorithn  of  tht  ctnttri 

y. 

[nn.an]*tizt(A):  [■c,nz]«ais«(Z) ;  S«[l,na;Sc]; 

itl«l: 

condBaz/bain/traca  (Z  ( 1 :  aa ,  1 :  aa) ) ; 

Ax^affin(A,z2):  Bx>affin(B.x2) ; 

laab(Ia2>aax  ( tig  (  Ax ,  Bx ) ) ; 
ftatB[l,it2,eond,laBbda2] ; 
ditp(ttat): 

condBl;  X  raaatt  eond  to  force  tecond  pats  through  netnea 

«hila(cond>prec) 

xl*x2; 

laabdal>laabda3 ; 

laabda3>  ( l-theta)*laabda2'»'theta*laabdal ; 
if  conttantb>Bl . 

F>adiag(-A.C): 

F(l:na,l:na)«F(l:na,l:aa)‘»'laabda3*B(l:na,l:na) ; 

Cx2 .  Z , it 2 , af ] •netnea3a( F , X 1 . S ) ; 

Ax«affin(A,z2): 
laabda2Baax(eig(Az) ) ; 

elae, 

F*adiag(laBbda3*B-A.C) ; 

Cx2,Z,it2,af]>BeaneB3a(F.zl .S) ; 

Ax>affin(A,z2);  BxBaffin(B,x2) ; 

laabda2>aax(eig(Az ,Bz) ) ; 
end 

cond>af /bain/trace(Z(  1 :  an ,  1 :  na) ) ; 
itlBitHl; 

BtatlB[itl,it2,coad,laabda2] ; 
if  laabda2>laBbda3 , 

error (’ cant era3  bloving  up*) 
end 

atat> [atat ; atat 1] ; 
diap(atatl); 
end 

xoptBx2: 

laabdaoptBlaabdaZ ; 
tolBcond ; 

return; 

y.  and  centara3 


1% 


assumplb 


function  orrsaiauaplbC A . B , C , z ,  Inabda) 

•/. 

*/.  •rr*nssuBpl(A,B,C,z,luibdn) 

y. 

y,  Doacription: 

y. 

y,  Thia  function  chocks  that  tho  initial  point  for  tho  algoritha  of  tho 
y.  cantors  is  admisoiblo. 

y. 

y.  Inputs: 

y. 

y.  A  a-matrix 
y.  B  a-matriz 
y.  C  a-matrix 

y,  z  voctor  conpatiblo  «ith  tho  a-aatricos. 
y,  lambda 

y. 

y.  Outputs: 

y. 

y.  orr  is  an  orror  coda,  orr*[0  0  0]  if  tho  initial  point  is  admissiblo,  orr<0 
y.  otharsiso. 

y. 

y.  Commonts: 

y. 

y.  Soo  function  cantors 

y. 

orr*C0  0  0] ; 

zlBmin(oig(lambda*aff  in(B  ,z)-aff  in(A,x) ) ) ; 
z2«min(olg(affin(B,x)}); 
z3«min(oig(affin(C,z))) : 
if  zl<«0 
orr(l)>zl: 
and 

if  z2<«0 
arr(2)3z2; 
and 

if  z3<«0, 
arr(3)sz3; 
and 

raturn; 

y.  and  assumplb 


assump2 


function  bminsassump2(A,B.C,z, bound) 

y. 
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V.  lMiin«astttBp2(A,B,C,x, bound) 

y. 

y.  Dotcription: 

y. 

y.  This  function  chock  that  ths  rsstriction  B(x)>0  is  boundsd  assy  Irom 
y.  bs  singular,  it  dstsninss  a  lovor  bound  bain  solving  an  auxiliary 
y.  nininization  problsn.  Zf  B(z)>B  constant  aatrix,  boiin  is  ths  nininua 
y,  sigsnvalus  of  B. 

y. 

%  Inputs: 

% 

y.  A  a-aatrix, 
y.  B  a-aatrix, 
y.  C  a-aatrix, 
y.  X  vsctor, 

y.  bound  is  a  bound  to  dstsct  that  C(x)  is  unbounded. 

y. 

y.  Outputs: 

y. 

y.  bain  is  a  bound  for  B(x) 

y. 

X  CoBUionts: 

X 

X  Sas  function  cantors 

X 

X 

Cna,aa]«siza(A); 

X 

X  If  B(x)  is  a  function  of  x 
X 

if  B(:  ,na'>'l:na)‘*zaros(na,Ba-na) 

Al—B; 

A2"aidaBt (siza(Al)): 
laabda«aax(aig(aff  in(Al  ,z) )  )-*'l ; 

[x  lopt ,  b ,  stat ,  arr]  «cantars  (  A1 ,  A2 ,  C ,  Sc ,  X ,  laabda ,  thsta  ,proc ,  bound) ; 
if  arr»»0 
bain*-b; 

also 

arror( 'Error  chocking  assuaption  (2)’); 
and 

X 

X  If  B(x)*B  constant  aatrix 
X 

also 

bBin*ain(aig(B( : ,  1  :na) ) ) ; 
and 

return ; 


assutnp3c 
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f unct  ion  [orr ,  xn«» ,  Inn ,  Z ,  it]  >MSttBp3c  (  A ,  B ,  C ,  Sc ,  z ,  lubdn ,  thotn ,  bound ) 

•/. 

V.  [orr . znotf ,  Inow , Z ,  it] >ntsunp3b ( A ,  B ,  C , Sc ,  z ,  laabda , thata , bound) 

•/. 

*/.  This  function  chocks  aaaunption  (3)  of  tho  nothod  of  cantors  using 
y.  ona  itaration  of  tho  cantors  nothod,  if  tho  nom  of  z  divargas,  than 
y.  an  unboundad  diroction  azists.  It  raturns  tha  analytic  cantor  x,  tha 
y.  valua  of  tha  nazinua  aiganvaluo  Inav,  and  an  arror  coda  which  is  arr>3 
y.  if  tho  problan  is  unboundad  and  orr^O  otharwisa. 

y. 

'/,  Inputs: 

y. 

*/,  A,B,C  a-natricas. 

Sc  natriz  with  tho  block  structura  of  C(x) 
y.  z  vactor 

y.  laabda  initial  valua 

y.  thata  paraaatar  of  tho  nothod  of  cantors. 

y,  bound  is  a  linit  for  tha  nom  of  x  to  datact  divargonca. 

y. 

y.  Outputs: 

% 

y,  arr  arror  coda.  arr«3  if  tha  problan  is  unboundad,  otharwisa  arr^O. 
y,  znaw  analytic  cantor. 

*4  Inaw  now  valua  of  laabda  for  znaw 
y.  Z»inv(F(z)) 

y.  it  is  tha  nuabor  of  iterations 

% 

%  Coaaants: 

y. 

%  Saa  function  cantors. 

y,  Nodifiad  to  call  gradZb.  usas  aigan  division 

Cna.na]>siza(A): 

Ax«affin(A,z) ; 

Bz«affin(B,z) ; 

lanbdal*naz(raal(aig(Ax,Bz))) ; 
lnaw«  ( l-thata)aianbdat't'thataalaabda ; 

F«adiag(lnav*B-A ,C) ; 

S«[l,na;Sc] ; 

x2«z:  dalta2*l:  it«0; 

shila  ( (dalta2>0 . 001  )k(norB(z2 )  <*30und ) ) 
zl«x2: 

daltal«dolta2; 

Eg ,  H ,  Fz .  af  ]  >grad2b(F .  z  1 ,  S ) ; 

CuH,dH]>aig(B): 
if  any(diag(dH)«*0), 

arror ( 'Bassian  collapsed  trying  to  analyze  assunp3'), 
and 

Bg«uB*  (diag(dB) . \(uB  *  *g) ) : 
dalta2*sqrt (g ' aBg) ; 
if  dalta2  >  .25 
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alpha>l/(l'»'d«ltt2) ; 

•It* 

•lphiL>l; 

•nd 

x2-zl-*lph**Rg; 

•nd 

[uF,«F3«*ig(Fx): 

Z*uF*(*F\uF'); 
if  •ny(diag(*F)<0) 

•rror('Fx  it  not  poiitiv*  d*finit*  in  atiiuip3c’) 

•nd 

xn*w«x2 ; 

Fx2>affin(F.x2); 
if  •ny(*ig(Fx2)<>0) 

ditp( 'Tnrainal  point  in  nttiuipSe  infontiblo-  rovortod  to  proviout’) 
xn*v>xl ; 

•nd 

if  non(x2)>bottnd 
•rr«3 : 

•It* 

•rr*0 : 

•nd 

r*tnm: 

%  •nd  •••uaip3c 


affin 

function  F  *  affin(A,x,col) 

V. 

y.  F  «  affin(A,x,col) 

y. 

y.  Datcription: 

y. 

y.  Thit  function  coaputoa  tb*  affin*  aatrix  •xprattion 
%  F  ■  AO  A1  xl  ...  t  Ar  xr.  If  A  it  an  Mtpty  a-natrix, 

%  th*  function  raturnt  F>n. 

y. 

%  Input*: 

y. 

X  A  it  an  a-aatrix  As[A0,Al, . . .  ,Ar]  , 

X  X  it  a  vactor  x>[xl, . . . ,xr] . 

X  col  it  tha  noabar  of  coluant  of  A,  if  not  provided ,  it  it  attuatd 
X  to  th*  nuabar  of  roat. 

X 

X  Output*: 

X 

X  F  it  tb*  aatrix  F  ■  AO  4-  A1  xl  ...  *  kr  xx. 

X 
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if  A»*C3 
F-D; 
return ; 

•Is* 

Dia,na]«si2«(A): 

[■z,nx]>siz«(z); 
if  nnrgin»2 
eol«M; 

•nd 

n*nn/col;  X  nuabar  of  ■strieos  in  A 

if  n'«anz(BZ,nz)'*-l 

•rror( 'Error  in  nffin.a.  Ineoapatibl*  diaonsions') 

•nd 

F«A(:,l;col); 
for  i*l:n-l 
j«col*i; 

F»F+A(:,j+l:j+col)*z(i): 

•nd 

•nd 

return ; 


adiag 


function  Faadiag(B,C) 

%  given  th*  a>aatrie*s  B  and  C,  finds  th*  a-aatriz  F  such  that 
%  affin(F,z)>[affin(B,z)  ,0;  0,  affin(C,z)] 

X 

X  calls  daug  froa  autools 

[nb,ab]«sizs(B) ;  Cnc,ac]>sizc(C) ; 
diaaab/nb; 

F»a; 

for  iaO:dia-l, 

klai*nb:  k2«i*nc; 

FaCF,daug(B( :  ,kl-»l :kl>nb)  ,C( :  ,k2'«-l :k2-t'nc))] ; 

•nd 

X  end  adiag 


Besrtgjn3ft 

function  [zopt,Z,it*r,af]>n«sn*a3a(F,z,S) 

X 

X  [xopt,Z,it*r]>n*sn*n3(F,z,S) 

X 
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y.  Description: 

y. 

y.  This  function  dstsrainss  th#  nnnlytic  center  ’xopt*  which  Biniaizes 
y.  the  barrier  function  f(x)«log  det  inv(F(z))  using  lesterov  and 
y.  Naairovsky's  levton  algoritha,  where  F(x)sF04-Fl*xl4'. .  .'fFr*xr. 

y. 

%  Inputs: 

y. 

y.  F  »  CF0.Fl,...,Fn]. 
y  X  s  Cxl,...,xn],  is  a  initial  value, 

y. 

y.  Outputs: 

y. 

y,  xopt  analytic  center 

y.  Z«inT(F(x))  which  will  be  used  later  in  the  stopping  criteria 
y,  for  the  aethod  of  the  centers,  actually  is  calculated  in  function 
y,  "grad" . 

y,  iter  nuaber  of  iteration  to  find  the  analytic  center. 

y. 

y.  Related  functions: 

y. 

y.  gradZb  coaputes  gradient  and  hessian  of  f(x)Blog  dot  inv(F(x)). 

y. 

y,  Conaents: 
y  Called  by  centers. 

y 

y.  This  version  uses  eigen  decoaposition  for  ill-conditioned  divide.  Coaputes  Z  out  of  loop. 

xl«x;  iter>0;  delta«l: 
while (delta>. 001) 

Cg,H,Fx,Bf]Bgrad2b(F,xl,S);  %  Determination  of  gradient  and  hessian 

CuH,dH]«eig(B); 

if  any(diag(dH)BB0), 

disp( 'Hessian  collapsed'), 
break 

end 

Hg«uH*  (diag(dH ) .  \  (uH '  *g) ) ; 

delta>sqrt(g'*Hg):  y  lewton  decreaent 

if  delta  >  .25 

alphaBl/d+delta) ; 

else 

alphv'l; 

end 

xlBXl-alpha*Hg; 

iterBiter't’l; 

end 

xoptBxl;  ZBinv(Fx): 
return ; 

y  end  nesneaSa 
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grad2b 

function  Cg,  H,  Fx,  af]  •  frnd2b(F,x,S) 

y. 

y.  Cg.  H,  Fx]  «  grnd2(F,x,S) 

y. 

y.  OMcription: 

y. 

X  This  function  dstsrainss  ths  grndisnt  *g'  and  ths  hossinn  *H' 
y.  of  tho  baxrisr  function  f(x)  «  log  dot  inv(F(x)), 

y,  gi(x)B-Tracs(ZFi).  i«l . . 

y.  Hij(x)-Traca(ZFi)(ZFj),  i»l . n. 

y,  Z*in»(F(x)) 

y. 

y.  Inputs; 

y. 

y.  F  «  [FO.Fl . Fn], 

y.  X  B  [xl . xn], 

y.  S  is  tha  block  structure  of  F(x).  Sb[s1  s2]  ,  vhara  si  is  a  vector 
y.  with  the  type  of  block  (typsBO  is  a  diagonal  block,  typsBi  is  a  full 

%  order  block).  s2  is  a  vector  vith  the  size  of  each  block.  If  does  not 

y.  exist  Matrix  S.  it  is  supposed  that  F(x)  is  a  conplete  full  order 
y.  block. 

y. 

X  Outputs: 

y. 

y.  g  gradient 
X  H  hessian 
X  Fx«  F(x) 

X 

X  This  version  differs  fron  the  original  by  taking  advantage 
X  of  MATLAB4*s  saart  division,  and  differs  fron  grad2  by  exploiting 
X  structure. 

X  Significant  flops  are  saved  by  taking  advantage  of  the  structure 
y,  of  the  argunent  of  the  trace  in  conputing  the  hessian. 

X  Block  division  is  desirable  since  ve're  forcing  an  ill-conditioned 
X  problen,  and  tha  snaller  the  blocks,  the  more  accurate  the  division 
X  will  be.  F(x)  should  be  PD,  so  aatlabd  will  use  cholesky  as  long  as 
X  the  subblocks  of  F(x)  renain  nunerically  PD. 

X 

X  Connents: 

X 

X  See  functions  nesnen  and  centers. 

X 

[nf ,nf]Bsise(F); 
if  narginBB2, 

SeCl.nf]; 

end 

[■s,ns]Bgizn(S); 
dinBnf/nf-l ; 

FxBaffin(P.x); 
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gczarosCdia,!);  H><«rot(<liB.diB);  lndl>l: 

for 

if  (S(j.l)— 0)  I  (S(j,2)— 1). 
for  iBl:S(j,2), 

FxF«Fz(indl ,  indl)\F(indl  ,indl‘*'af  :Bf :  indl‘«'dlB«af ) ; 
g»g-FxF’ ; 

H«H+FxF**FxF; 

indlBindl-t’l; 

•nd 

flizo*S(j,2);  kl>indl:indl-l'fsiz«;  k2BZ«roi(l,sizo*diB); 

for  i>l:diB, 

k2(l'«’(i-l)*iiz«:i*siz«)>kl‘*'i*Rf ; 

•nd 

FxF-Fx(kl  ,kl)\F(kl  ,k2) ; 
for  i«l:dlB, 

ll>FxF( :  .siz«*(i-l)<f  1  :iiz«*(i-l)-fsiz«) ; 
g(l)«g(i)-trac«(ll); 

for  k>l+l:diB, 

12>FxF(:.slz««(k-l)-«^l:iiz«*(k-l)'fsiz«); 

H(l,k)>R(i,k)‘fttui(sua(ll.*12')): 

H(k,i)«H(i,k)i 

•nd 

•nd 

lndlBindl<«-siz^i 

•nd 

•nd 

return; 

%  •nd  grnd2 
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APPENDIX  D:PLANT/CONTROLLER 
OPTIMIZATION  CODES 

This  appendix  documents  the  MATLAB  script  and  function  files  which  were 
used  in  solving  the  example  problems  discussed  in  Chapter  V.  The  first  section  is  the 
function  files  which  perform  the  optimization.  These  functions  are  independent  of 
the  specific  example  to  be  solved,  but  instead  solve  a  general  class  of  problem,  such 
as  the  joint  “Hoo  pole  placement  problem.  The  second  section  is  the  scripts  which 
were  used  to  prepare  the  synthesis  models  for  the  example  problems.  The  outputs  of 
these  scripts  were  used  as  the  input  arguments  for  the  optimization  functions  in  the 
first  section. 

A.  PLANT/CONTROLLER  OPTIMIZATION  FUNCTIONS 

This  section  documents  the  function  files  which  perform  the  plant  controller 
optimization  process.  These  functions  all  had  similar  structure,  and  input  and  output 
arguments.  The  input  arguments  included  the  synthesis  model,  initial  plant  and  cost 
vector  ,  and  the  optimal  plant  and  associated  controller  were  outputs.  The  synthesis 
models  were  required  to  be  state-space  representations  of  the  plants  with  A,  and 
B2  expressed  as  “a-matrices”  of  the  associated  plant  variables.  That  is  if: 

A  =  A(C)  =  Ao  +  ^C.Am 

1=1 

R,  =  i3(C)  =  i3,o  +  i;C./?i., 

isl 

Bj  =  B(C)  =  ^20  +  51  Ci^2i^ 

i=I 
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then  the  associated  a-matrices  were  Aa=  \Ao,A\ . Ar],  Bla=  i3i,, . . . ,  fii 

and  B2a=  [Bjo,  ^2|  <  •  •  •  i  matrices  Aa,  Bla,  and  B2a  are  then  the  bases  for 

the  plant  matrices  A,  /?),  and  B}. 

Per  Chapter  V,  the  general  method  was  to  first  find  a  feasible  controller  which 
minimized  the  controller  margin  for  the  initial  plant  (maximized  its  absolute  value), 
then  freeze  the  controller  while  minimizing  the  cost  function  J  =  c^C,.  Both  the 
controller  optimization  and  the  plant  optimization  were  performed  using  the  interior 
point  function  cantarsS  documented  in  Appendix  C. 

The  first  plant  optimization  code  (plantopt2),  which  employs  a  single  Hoc 
constraint,  provided  the  baseline  structure  for  all  that  followed.  Consequently,  in  the 
interest  of  volume,  this  code  alone  is  thoroughly  documented. 

1.  Plant  and  Controller  Optimization  for  an  Hoc  Performance  Con> 
straint 

The  function  plantopt2  and  its  associated  subroutines  solves  the  plant/ 
controller  optimization  problem  with  a  pure  Hoc  performance  constraint.  From 
Chapter  V,  the  general  method  revolves  about  two  EVP’s.  Algorithmically: 

1.  Evaluate  A(C),B\{()  ,  and  B2(C)- 

2.  Determine  Hoo  fea.sibility  for  the  initial,  and  find  a  particular  solution  (IVp,  Vj,) 
to  the  Riccati  Hoo  analysis  equation. 

3.  Create  a  basis  Z  for  the  controller  variables  W.  and  1^. 

4.  Find  the  vector  (  which  maps  Z  to  (VFp,  Vj,). 

5.  iter  Using  /1(C), B|(C)  ,  and  B^iQ,  and  the  basis  Z,  find  the  basis  for  B],  the 
Hoc  LMl,  equation  5.2. 
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6.  Find  a  feasible  initial  eigenvalue  Ao  for  the  inequality  XqI  —  Ri(^)  >  0. 


7.  Use  the  method  of  centers  to  find  a  controller  (represented  by  a  new  which 
satisfies  the  Hoo  LMI: 

Minimize:  A  (over  ^), 

Subject  to: 


XI-Ri(C()  0 

0  K(0 


>0. 


(D.l) 


Note  that  A  must  be  negative  for  the  problem  to  be  feasible. 


8.  Verify  that  A  represents  a  feasible  solution,  or  that  A  is  not  so  small  as  to  satisfy 
the  termination  criteria. 


9.  Evaluate  W(^),  V(0. 


10.  Using  W  and  and  the  plant  bases  matrices  Aa,  B\a  and  B2a,  find  a  basis  for 
the  alternate  Hoc  LMI  (equation  5.3). 


11.  Now  optimize  the  plant  cost  J  =  c^(,\  subject  to  the  Hoo  constraint,  and  the 
constraint  that  the  plant  variables  must  have  positive  value: 

Minimize:  J  (over  (), 


Subject  to: 


J  -  c^C  0  0 

0  diag(C)  0 

0  0  -R2{C0 


>0. 


(D.2) 


12.  Evaluate  the  new  plant  A(()yBi(Q  ,  and  Bji^. 


13.  Go  to  step  iter  until  exit  criteria  is  satisfied. 


The  progress  of  this  algorithm  is  supported  by  a  number  of  subroutines. 
Feasibility  is  tested  by  Ricrati  solvers  from  the  /<-Tools  toolbox  to  determine  an 
initial  feasible  solution.  Note  that  this  particular  solution  is  not  precisely  feasible  in 


the  since  of  the  LMI’s,  since  it  represents  the  solution  of  a  Riccati  equality  rather 
than  inequality.  The  inequality  will  he  enforced  the  first  pass  through  the  algorithm, 
and  the  Riccati  solution  being  “close”  to  a  solution  of  the  inequality  dramatically 
reduced  the  computational  workload  on  the  first  pass.  From  the  plant  and  a-matrices 
for  the  controller  variables,  the  basis  matrices  for  the  constraint  functional  on  (  are 
constructed  by  the  subroutine  hinfresS.  The  interior  point  algorithm, centersS, 
then  finds  a  controller  that  minimizes  the  controller  margin.  The  controller  margin 
must  be  negative  for  the  controller  to  be  considered  feasible  and  for  the  algorithm  to 
proceed.  Furthermore,  if  the  absolute  value  of  the  controller  margin  is  less  than  some 
small  numerical  threshold  (typically  10“®  to  10“'®),  then  the  feasible  set  is  too  small 
practically  to  proceed,  and  the  loop  is  exited.  This  is  the  usual  exit  path.  If  these 
criterion  are  satisfied,  the  code  proceeds  to  the  plant  optimization  phase.  Using  the 
above  controller,  the  function  hinf  re84  builds  the  basis  matrices  for  the  constraint 
functional  on  (•  The  interior  point  code  is  then  called  again  to  optimize  the  plant 
cost  (over  C)*  The  loop  can  also  be  exited  at  this  point  if  the  cost  does  not  decrease 
from  iteration  to  iteration,  or  if  the  maximum  iteration  count  has  been  reached.  If 
the  cost  has  been  successfully  decreased,  then  the  algorithm  returns  to  the  controller 
design  phase  to  find  a  new  controller.  The  optimal  plant,  controller,  and  algorithm 
history  are  returned  as  outputs.  The  other  called  subroutines  are  administrative,  and 
are  described  in  Appendix  C. 

plantopt2 

function  Cz«ta,zi,K,Z,llc,Tc,  J3,«rr]*. . . 

pl«ntopt2(Am,Bla,B2n,C,D,z*tn,««ight,thr«s,gna,th«tn,proc) 

y. 

y.  Cz«tn,zi,K,Z,Rc,Te, J2,«rr]>plantopt2(An,Bl«,B2n,C,D,z«ta,*«ight,thr«i,gnB,th«ta,proc) 
y.  Cztta,zi,K,Z,Re,Te,J2,arr]>plantopt2(Aa,Bla,B2a,C,D,zata,«aight,thraa) 
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y. 

Vt  Description: 
y.  Given: 

y,  zdot  s  AX'*-Bl*-«-B2Ut 
y,  z  «Cx-«-  Du, 

y.  y  »  X, 

y. 

y.  This  function  determines  the  miniaua  stete-feedbeck  plant  satisfying 
y.  I  iT.zwl  l.infty  <  gaasa 

y. 

y,  ain  J«ueight*zata 
y,  subject  to: 

y. 

y,  R(Z)*AY+YA'+B2H  +W*B2'*B1B1 '♦(CY  +DH)*  (CY  +D«)<  0, 

y. 

y.  Code  alternatively  finds  central  controller,  and  Biniaizing  plant 
y,  using  the  method  of  centers  to  solve  equivalent  LNZ's. 

y. 

y.  Inputs: 

y. 

y,  C,D  are  constant  matrices  from  the  state-space  realization  of  the  system, 
y.  Aa,  Bla  and  B2a  are  a-matriees  which  hold  the  affine  elements 
y,  zeta  is  the  vector  that  defines  the  initial  plant  (ABaffin(AA,zeta)) 
y,  weight  is  the  row  vector  of  weights  in  the  objective  function 
y.  three  is  the  threshold  on  the  central  controller  margin 
y,  for  determining  when  to  quit  the  iterative  procedure 

y,  gam  is  a  bound  of  the  H-inf  norm  for  the  closed  loop  system, 
y.  theta  parameter  of  the  method  of  centers 

y,  prec  is  used  by  the  method  of  centers  to  determine  when  to  quit  the  newton 
y.  search  for  the  analytic  center.  The  default  is  0.001,  bur  if  the  ricatti 

y,  soln  indicates  that  the  problem  is  feasible  and  yet  the  method  of  centers 

y,  cannot  find  a  solution,  then  this  parameter  should  be  adjusted  to  something 

y,  smaller  to  allow  the  newton  search  to  go  deeper. 

y.  If  the  ricatti  solvers  indicate  that  the  problem  is  feasible  and  yet  the 

y,  method  of  centers  cannot  find  a  feasible  controller,  then  this  parameter 

y.  should  be  set  smaller. 

y. 

y.  Outputs: 

y. 

y,  z  is  the  optimized  vector  of  plant  parameters 
y,  xi  is  the  vector  of  controller  parameters 
y,  K  the  state-feedback  gain  matrix 
y,  Z  is  the  basis  for  the  controller  matrices  W,Y 

y.  Rc,  Tc  are  the  bases  for  the  controller  and  plant  optimization  constraints 
y,  J2  is  the  history  of  the  problem 
y,  err  is  an  error  flag 

y. 


y.  Called  functions: 

y,  basis,  computes  a  basis  for  a  set  of  block  structured  matrices 
y,  hinfres,  computes  the  a-matrix  of  a  Riccati  inequality  restriction 
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X  adlag,  coaputas  tha  a-aatriz  of  diag(A(z),B(x)) 

X  atraca,  coaputaa  tha  a-aatriz  of  traca(R,X) 

X  aidant,  givaa  an  a-aatriz  with  tha  indapt.  tara  aquals  unity  and 
X  tha  raft  of  aatricas  aaroa. 

X  gatvac,  givaa  tha  raalisation  of  a  aatrix  in  a  aatriz  baaia. 

X  affin,  coaputaa  an  affin  aatrix  function. 

X 

X  Coaaanta : 

X 

X  Tha  aaauaptiona  for  thia  function  ara  atandard  in  tha  atata-faadback 
X  Rinf  caaa,  (A,B1)  atabilizabla  and  01  haa  full  coluan  rank. 

X  Thaaa  aaauaptiona  ara  not  ehackad,  though  thay  probably  ahould  ba. 

X  If  tha  inputa  gaa,  prae  and  thata  ara  not  providad,  thay  ara  initializad 
X  to  1,  0.1  and  0.001  raapaetivaly . 

if  nargin<ll 

gaa«l;  thata«0.1;  pracc.OOl; 

if  narginac?, 
thraa«lo-6 
and 
and 

[na,na]>aiza(Aa):  diazcna/aa; 

[abl ,nbl]Baiza(Bla) ;  nql«nbl/diaz; 

Cab2 ,nb2] «aiza(B2a) ;  nq2>nb2/diaz ; 

Cac,nc]«aiza(C) ; 

X  Dataraina  initial  plant 

A«aff  ia(Aa,zata) ;  BlaaffinCBla.zata.nql) ;  B2«aff  in(B2a,zata,nq2) ; 

X  Dataraina  hinf  faaaibility/cantral  controllar 
X  by  aolving  hinf  aynthaaia  haailtonian 
a»A-B2*((D'*D)\D»)*C; 

haa«[a,  ((Bl*Bl'/gaa*2)-B2*((D**D)\B2’));  -C’*(aya(nc)-D*((D**D)\D’))*C,  -a’]; 
[xl ,x2,fail]«ric.achr(haB) ;  Xinf «x2/zl ; 

if  (fail>0)  I  aay(aig(Xiaf )<0) , 

diapC Initial  Syataa  appaara  infaaaibla-1’):  raturn 

alaa 

diap( 'Initial  Hinf  problaa  faaaibla') 
and 

Kp«-(D'*D)\(D'aC'»B2'*Xinf):  X  "cantral"  controllar 

X  Dataraina  particular  aoln  froa  central  controllar 
X  by  aolving  hinf  analyaia  haailtonian 

al>A'fB2'*Kp:  bl>[Bl,10000*aqrt(apa)aaya(Ba)];  clsCaDaKp; 

[xl ,z2 ,f ail]>ric_achr ( Cal ' ,cl 'acl ; -bl*bl ' ,-al] ) ;  YpBx2/xl ; 

if  (fail>0)  I  any(aig(Yp)<0), 

diapC Initial  Syataa  appaara  infaaaibla-2*):  ratum 
and 

Wp-Kp*Yp; 
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•/. 

'/.  Initializing  tha  optiaization 

•/. 

[Z,YY,diaz]Bbasis2(aa,nq2) ; 
xi=gatvac2([Yp:Vlp]  ,Z); 
Syy*Cl,aa] ; 

Rbsaya  (aa'fac ,  (diaz-«’l )  *  (aa'fac ) ) ; 
Rc=[zaros(aa,aa) ,YY] ; 

Ta*C0,  waight]; 
Tb«aya(l,langth(Ta)); 
Jsvaightazata; 
laas-1; 

J2sC];  itarationsO; 

CD=[C  D]; 

whila  laa<-ia-12. 


y,  bttilda  tha  baaia  Z  for  U,Y 
%  gat  initial  xi  froa  initial  controllar 
y.  aatabliahaa  tha  atructura  of  Y 
y,  aat.  baaia  for  controlar  EVP 

y.  aat.  baaia  for  plant  EVP 


aiaplifiaa  arguaant 


it  arat  ions  it  ar  at  ion'f  1 


y. 

%  For  fixad  plant-  find  tha  optiaal  controllar  (baat  controllar  aargin) 

y. 


diap( 'aaarching  for  nav  controllar') 
y.  craata  tha  baaia  for  tha  hinf  conatraint 
[Ra,Sc2]>hinfraad(CA  B2]  ,CD,B1*B1  *  ,gaa,Z); 

y,  dataraina  initial  laabda  for  EVP  and  add  aoaa  alop  to  aaka  it  faaaibla 
y.  thia  takaa  cara  of  changing  tha  aquality  abova  to  inaquality 
laain«nax(aig(affin(Ra,xi)))  4  0.1; 

y,  find  tha  aat  of  controllar  paraaatara  *xi'  which  ainiaiza  tha 
y.  controllar  aargin  'laa' 

[xiop,laa,atat,arr2]«cantara3(Ra,Rb,Rc,Syy,xi,laain,thata,prac,lal2) ; 

if  arr2**0, 

arr^S;  ratum; 

y.  taminata  if  cantara  couldn't  find  a  faaaibla  controllar  (lan>sO), 
y.  or  tha  aargin  waa  too  aaall  to  bothar  procaading  (laa>-thraa) 
alaaif  lan>«0,  %  faaaibility  critaria 

diap( 'cantara  lould  not  find  a  nav  faaaibla  controllar*) 
braak 

alaaif  laBi>-thraa,  %  tamination  critaria 

diap( 'faaaibla  aat  too  amall  to  procaad') 
braak 
and 

y,  build  nav  controllar  U,Y  from  xi 
YV>aff  in(  [zaroa(Bia4nq2.aui)  ,Z]  ,xiop,aia) ; 

Y*YH(1 ;na, : ) ;  V«YV(na41 ;na4nq2, : ) ; 
xi«xiop; 
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K»tf/Y: 


% 

%  Fix  eontrollar-  solv*  th«  ain  airfraac  problam 

y. 

diapCOptiaizing  plant  for  praviout  controllar*} 

y  naing  tha  controllor  abova,  find  tha  baaia  for  hinf  raatriction 

CTc,Sc]>hinfraa4(Aa,Bla.B2a.YW,CD.gaa); 

y,  add  aoaa  padding  to  pravioua  optlaua  coat  to  aaka  problaa  vary  faaaibla 
y,  optiaica  tha  plant 

[zataop ,  J ,  atat ,  arr2]  «eantara3  (Ta  ,Tb  ,Tc  ,Sc ,  zata ,  J ,  thata ,  prac ,  1  a  12 ) ; 
if  arr2"«0 
arr>3: 
raturn; 

and 

zata^zataop: 

X  Build  tha  na«  plant 

A>aff in(Aa.zata) ;  Bl>aff in(Bla,zata,nql) ;  B2Baff  in(B2a,zata,nq2) ; 
diap(Clan,J]) 

X  Stack  tha  data  for  output  hiatory 
J2«CJ2i  Ian,  J,  zata']: 
diapCCloaad  Loop  Polaa"') 

E-alg(AaB2aK) :  diap(E') 

if  any(raal(E)»0), 
arr*4; 
ratum 

and 

X  altarnata  taraination  critaria  (thia  ia  only  a  back-up  to  abova) 
if  itaration>2, 

if  (J»J2(itaration-l,2))  I  itaration»100, 
braak 
and 
and 


and 

X  Datamina  tha  controllar 

Y-T«(l:aa,:)j 

V>YV(aa*l:na4^nq2.:); 

K»W/Y; 

X  plot  tha  optiaization  hiatory 

loglog(-J2(:  ,1) ,J2(:  ,2), '*'),grid,titla('Plant  Coat  va.  Controllar  Margin') 
zlabaK 'Controllar  Margin' ),ylabal( 'Plant  Coat') 
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•rr*0 : 
return; 

y.  end  plantoptS 


hinfres6 

function  CF,Sf]Bhlnfr«s6(AB,CD,BlBl,guii,Z) 

y. 

y.  CF .  Sf ]  >hinf r«i6( AB ,  CD ,  BlBl ,  gam ,  Z ) 

y. 

y.  Description: 

y. 

y.  This  function  detemines  the  e-antrix  of  the  convex  restriction 

y. 

y.  I  AB*YH  +  (AB*YW)’  +  BlBl  (CD*YW)'  I 

y.  R(Z)  *  I  2  I  <  0, 

y.  I  CD«YU  -gsst  1  I 

y. 

y. 

y.  Inputs: 

y. 

%  AB,CD,BlBl,gaa  psraaeters  of  the  restriction 
y«  Z  basis  for  YV  froa  basis2 

y. 

y.  Outputs: 

y. 

y.  F  a-aatrix  of  the  restriction 
y.  Sf  block  structure  of  F 

y. 

'/t  Coaaents: 

y. 

%  Note  that  in  order  to  obtain  the  value  of  the  restriction,  *e  need  a 
V,  vector  x^Cxl, . . .  ,xr]  ,  then  F(x)>F0-»^Fl*xl-i’. .  .Fr*xr,  the  block  structure 
y.  of  F(x)  is  Sf. 

y. 

y.  this  basis  uses  the  reduced  order  problea 

Cmz,nz]>size(Z); 

[aa,nB]>size(AB) ; 

Car,nr]Bsize(CD): 

Cas,ns]Bsize(BlBl); 

diaanz/aa;  aaroaa't-ar; 

F*zeros(anr,aar*dia) ; 

F( : ,  1  :aaa:)>CBlBl ,zeros(aa.ar)  ;zeros(ar  ,aa)  ,-gaa*gaa*e]re(ar)] ; 
F3Bzeros(ar} ; 
for  iBl:dia, 

YHbZ(  : ,  (i-l)*Mi^l :  (i-l)*aa4aa) ; 

F1*AB*YW:  F2«CDeYW; 
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F( : , i*»ur+l :  (i+1) •■»)■[«♦« •  ,F2 *  :F2,F3] ; 

•nd 

SfBCl.nK-wr] ; 
raturn; 

X  and  hlnfraad 


hinfres4 


f unct ion  [R  >  Sf ] ahiniraai ( An , B 1 a , B2a , YV , CD ,gaa) 

X 

X  [R,Sf]Bhinfraa4(Aa.Bla.B2a.YV.C0,gaB) 

X 

X  Daacriptlon: 

X 


X  This  function  dataninas  tha  a-aatrix  of  tha  convax  rastriction 
X 

X  I  AY4^B2Vm*4^V>B2*-f(CYOV)*(CY4DU)  B1  I 

X  R(zata)  >1  I  <  0, 

X  I  Bl'  -  aya  I 

X  - 

X 

X  Inputs: 

X 

X  Aa,Bla,B2a  ara  a-suitricas  of  tha  plant 

X  YV,C0,gasi  paraaatars  of  tha  rastriction  (YV  is  tha  paekad  fora  CY:V]) 
X 

X  Outputs: 

X 


X  R  a-aatrix  of  tha  rastriction  (-R>0  is  actually  ratumad) 

X  Sf  block  structure  of  R 
X 

X  Coaaants : 

X 

X  Rota  that  in  order  to  obtain  tha  value  of  the  rastriction,  *a  need  a 
X  vector  xb[x1,  . . .  ,xr] ,  than  R(x}>R04’Ri*xl'*'. .  .Rr*xr,  tha  block  structure 
X  of  R(x)  is  Sf. 

X 


[aa,na]Bsizo(Aa): 

[abl,nbl]Bsiza(Bla) ; 

[Bb2,nb2]Bsiza(B2a) ; 
diazBdia-1 ; 

FlaCAaC: ,l:aa),B2a(: ,l:nq2)]sYV; 

CYDWBCD*YU/gaa;  CY0U2« 

R*zaros(il,dia*(il)); 

R(dia:il,dia:il)B-CFl'«’Fl'-*'CYDV2,  Bla( :  ,l:nql):  Bla(:  ,l:nql)  ’  ,-aya(nql)]  ; 
for  iBl:diaz, 

R(i,i4>il*i)>l: 


diavna/aa; 

nql^nbl/dia; 
aq2Bnb2/dia; 
ilBdiaz'Hsa^'aql ; 

CYDW’aCYDW; 
F3«zaros(nql) : 
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Fl*CAa(:  ,i*aa-*'l:i*U'fu),B2a(:  .ianqS-t'l :i*nq2'«-nq2)]*YV; 
F2«Bla(:  ,l*nql‘<-l:l*nql'*’nql); 

R(di«:  il ,  (i*il+di«):  (1*11+11))*- [Fl+Fl  •  ,F2;F2*  ,F3]  ; 
and 

Sf  *  [zaroa  (dlnz ,  1 ) ,  onaa  (dlu .  1 ) ;  1 ,  aia+nql]  ; 
raturn ; 

*/•  and  hlnfraa4 


2.  Plant  and  Controller  Optimization  for  an  Hoo  Performance  Con¬ 
straint  at  Multiple  Flight  Conditions 

The  function  plantoptS  solved  the  multiple  flight  condition  problem.  It 
called  the  identical  subroutines  as  plantopt2  above,  and  differed  only  slightly  in 
structure.  During  the  first  pha.se  three  independent  controllers  were  calculated  for 
the  three  respective  flight  conditions.  The  second  phase  then  stacked  the  constraint 
functionals  so  as  to  jointly  perform  the  plant  optimization.  The  subroutine  adiag 
performed  the  administrative  task  of  stacking  a-matrices  for  the  imposition  of  joint 
constraints,  and  is  documented  in  Appendix  C. 


plantoptS 


function  [z«ta,zll,zl2,xl3,Z,J2,«rr]«. . . 

plantoptS  (An,  Bin, B2a,A«2,Bla2,B2a2,A«3,Bla3,B2«3,C,0,z*tn,  weight, gui,th«ta,pr«c) 

•/. 

X  CK,val,orr]*h2hlnf If (Aa,Bla,B2a,C,D,z«ta, weight, gaa,th*ta,pr«c) 

%  CK,val, err] Bh2hlnfaf(Aa,Bla,B2a,C,0,zeta, weight, gan) 

y. 

y.  Deecrlptlon: 
y.  Given: 

y.  zdot  *  A  X  +  B1  w  +  B2  u, 
y.  z  *  C  X  +  Du, 

y.  y  *  X. 

y. 

%  Thla  function  detemlnee  the  alnlnua  etatefeedback  plant  eatlefylng 
X  llT_zwlLlnfty  <  gaiaa 
y.  nln  J*welght'*zeta 
X  Bubject  to 
X 
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%  R(Z)«AY*Y»'+B2W  '♦(CY  ♦DW)*  (CY  ♦DW)<  0, 

X 

X  Cod*  *lt*rnatiY*ly  Yiiids  controll«r,  and  Binlalzing  plant 
X  using  th*  Bathod  of  cantors. 

X 

X  THIS  CODE  IS  THE  AIAL06  TO  PLAIT0PT2  AID 
X  FIIDS  THE  SIMULTAIEOUS  OPTIMUM  FOR 
X  MULTIPLE  FLIGHT  COIDITIOIS 
X 

X  Inputs: 

X 

X  C,D  ar*  constant  Batricas  froB  th*  stata-spaca  raalisation  of  th*  systaa. 
X  Aa,  Bla  and  B2a  ar*  a-Batrlcas  ahlch  hold  th*  affln*  alaaants 
X  sata  is  th*  vactor  that  dafinas  th*  initial  plant  (ABaffin(AA,z*ta)) 

X  vaight  is  tha  ro«  vactor  of  weights  in  th*  objactiva  function 
X  gsB  is  a  bound  of  tha  l-inf  nom  for  th*  closed  loop  systaa. 

X  theta  paraaatar  of  tha  aathod  of  cantors 

X  prac  precision  in  th*  eonputa  of  th*  upper  bound  of  th*  12  nora. 

X 

X  Outputs: 

X 

X  K  tha  gain 

X  val  tha  optiBUB  value  of  th*  parforaanc*  index  conputad  by  cantors 
X  algoritha 

X  arr  error  coda,  its  value  is  arr«l  if  th*  probloB  is  infeasiblo, 

X  otharwis*  *rr>0. 

X  Called  functions: 

X  basis,  coaputas  a  basis  for  a  sat  of  block  structured  aatricas 
X  hinfras,  coaputas  th*  a-aatriz  of  a  Riccati  inequality  restriction 
X  adiag,  coaputas  th*  a-aatrix  of  diag(A(x),B(x)) 

X  atraca,  coaputas  th*  a-aatrix  of  trac*(R,X) 

X  aidant,  givas  an  a-aatrix  with  tha  indapt.  tom  equals  unity  and 
X  tha  rest  of  aatricas  zeros. 

X  gstvac,  givas  th*  raalisation  of  a  aatrix  in  a  aatrix  basis. 

X  affin,  coaputas  an  affin  aatrix  function. 

X 

X  Coaaants: 

X 

X  Th*  assuaptions  for  this  function  ar*  standard  in  th*  stata-faadback 
X  Hinf  case,  (A,B1)  stabilizabl*  and  D1  has  full  coluan  rank. 

X  Thas*  assuaptions  ar*  not  chackad,  though  they  probably  should  b*. 

X  If  th*  Inputs  prac  and  thata  ar*  not  provided,  they  ar*  initialized 
X  to  0.1  and  0.001  raspactivaly. 
if  nargin>s8 

thataBO.l;  prae>.001; 

and 

[na,na]Bsiz*(Aa);  dinz«Ba/Ba: 

[Bbl,nbl]Bsiz*(Bla);  nql^nbl/diaz; 

CBb2 ,nb2] Bsiz*(B2a) ;  nq2>nb2/diBz ; 

[nc,nc]Bsiz*(C) ; 
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*/t  Flight  Condition  1 
V.  Dotonino  foasibilitjr/controllor 

A«nffin(An,zota) ;  Bl>alf in(Bla,zota,nql) ;  B2*aflin(B2a,z«ta,nq2) ; 

a»A-B2*((D'*D)\D')*C; 

ham*Ca,  ((Bl*Bl*/gaa*2)-B2*((D'*D)\B2'));  -C'*(ayo(Bc)-D*((D'*D)\D'))*C,  -a']; 
[xl ,x2,fail]>ric_achr(haa) ;  Xinf «x2/xl ; 

if  (lail>0)  I  any(aig(Xinf)<0), 

disp( ’Initial  Syataa  appoars  inltaaiblo-l’);  rotuni 

olio 

dispCinitial  Hinf  problon  foaiiblo’) 

•nd 

Kp»-(D’*D)\(D'*C+B2’*Xinf):  %  controllor 

%  Dotorvino  particular  soln  from  controllor 

alaA'fB2oKp:  bi«CBl,10000*oqrt(opi)*oyo(Ba)] ;  cl>C4’D*Kp; 

[xl,x2, fail] sric.ichrC Cal’, cl ’•cl;-bl*bl’  ,-al]) ;  Ypl>x2/xl ; 

H  (fail>0)  I  any(oig(Ypl)<0), 

dlip( ’Initial  SyotOB  appoars  inloasiblo-2’ ) ;  rotum 
ond 

Upl>Kp*Ypl : 

%  Flight  Condition  2 

'/,  Dotomino  loasibility/controllor 

A2Baffln(Aa2,zota) ;  B12>alfin(Bla2,zota,nql) ;  B22>affin(B2a2,zota,nq2) ; 
aBA2-B22*(  (D  ’ '»D)\D  ’  )*C; 

haa-Ca,  ((B12*B12’/gaB*2)-B22*((D’oD)\B22’))  i-C’o(oyo(Bc)-0*((D’*D)\D’))oc.-a’] ; 
[xl ,z2,fail]Bric_schr(hsB) ;  XinYBz2/xl ; 

if  (Xail>0)  I  any(oig(XiBf)<0), 

dispC 'Initial  SystoB  appoars  lnfoasiblo>l’);  rotum 

olso 

dispCinitial  Hinf  probloB  foasiblo’) 

ond 

Kp*-(D’*D)\(D’*C*B22’*Xinf):  %  controllor 

X  DotorBino  particular  soln  froB  controllor 

alBA2-*'B22oKp;  bl«CB12,10000*sqrt(ops)*oyo(Ba)] ;  clBODoKp; 

Cxi  ,x2,f  all]  *ric_schr(  Cal  ’  ,cl  ’*cl ;  -bl*bl  ’  ,-al] ) ;  Yp2Bx2/xl ; 

if  (fail>0)  I  any(oig(Yp2)<0). 

dispCinitial  SystoB  appoars  infoasiblo-2’) ;  roturn 
ond 

Vp2>Kp*Yp2; 

X  Flight  Condition  3 
X  DotorBino  foasibility/controllor 

A3Baffin(Aa3,zota) ;  B13Baff in(Bla3,^’ota,nql) ;  B23Baff in(B2a3,zota,nq2) ; 
a»A3-B23o ( (D ’ oD ) \D ’ ) *C ; 

haB>Ca.  ((B13*B13’/gaB‘2)-B23*((D’oD)\B23’));-C’*(oyo(Bc)-D*((D’*D)\D’))*C.-a’]; 
Cxi , x2,f ail] >ric.schr(haB) ;  Xinf bx2/x1 ; 

if  (fail>0)  I  any(oig(Xinf )<0) , 

disp( ’Initial  SystoB  appoars  infoasiblo-l ’) ;  rotum 
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dlsp( ’Initial  Hint  problaa  laanibla*) 
•nd 

Kp«-(D'*D)\(D’*C<fB2’*Xinf ) ;  X  eontrollar 


X  Dataraina  particnlar  sola  froa  eontrollar 
al>A3'fB23aKp:  bl«CB13,10000*aqrt(aps)*aya(aa)] ;  el>C'»D*Kp: 

[zl  ,x2  ,f  ail]  >ric_schr(  Cal  ’  .cl  *«cl  ;-bl*bl  *  .-al] ) ;  Yp3>z2/xl ; 

if  (lail>0)  I  any(al|(Yp3)<0), 

disp( ’Initial  Systaa  appaars  inlaasibla-2’):  raturn 
and 

Hp3>Kp*Yp3; 


X 

X  Initializing  tha  optiaization 

X 

CZ,YY,diaz]>basis2(aa,nq2) ; 
Rb>aya(aa-t'ac ,  (diaz4i)«(aa>ae) ) ; 
CD«CC  D]; 

Ta»CO,  vaight]; 

Jasaigbtazata; 
xilBgatvac2( [Ypl :Vpl] ,Z) : 
xi2>gatvac2(CYp2:Vp2]  ,2); 
xi3>gatvae2( CYp3:tfp3]  ,Z) ; 


Syy«[l,aa]: 
Re*Czaros(aa,Ba) ,YY] ; 

Tb>aya(l.langth(Ta)) ; 
laa«-l; 

J2>  □ :  itaration>0 ; 


shila  laa<-la-12. 


it  ar  at  ion>  it  arat  ion'^  1 
X 

X  daiining/solving  tha  eontrollar  problaa-flt  cond  1 
X 

dispCsaarehing  for  na*  eontrollar-  fit  cond  1’) 

CRa,Se2]ahinfras6(CA  B2]  ,C0,B1*B1’  ,gaa,Z); 
laain«aax(aig(affln(Ra,zil)))  0.1; 

[xiop ,  laal ,  St  at ,  arr2]  acant  ars3b  ( Ra ,  Rb .  Re ,  Syy ,  X  i  1 ,  laain ,  thata ,  prac ,  1  a  1 2 ) ; 
if  arr2*s0, 

arra3;  ratnm; 
alsaif  laa>sO, 

dispC’cantars  could  not  find  a  nav  faasibla  eontrollar') 
braak 

alsaif  laa>-la-6, 

disp( ’faasibla  sat  too  saall  to  procaad’) 
braak 
and 

YWlaaff  ln(  Czaros(Batnq2,aa)  ,Z]  ,xiop,Ba) ; 
xil>xiop; 


X 

X  dafining/solving  tha  eontrollar  problaa-flt  cond  2 
X 

disp( ’ searching  for  now  controller-  fit  cond  2’) 
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[Ra.Sc2]*hlnfrM6( [12  B22]  ,CD.Bt2*B12*  .gui.Z) : 
luilnaBax(«ig(«f<lxi(IUi,zi2)))  0.1; 

[xiop»laa2,f  tat,  •rr2]>cmt«rs3b(Ra,Rb,Rc,Syy,xi2,luiin,  theta, pr«c,  1*12) ; 
if  arr2’»0, 

arr>3;  return; 
elseif  laa2>«0, 

diepC 'centera  could  not  find  a  nev  feaaible  controller  (fc2)') 
break 
end 

YV2«aff  in(Cxeroa(Ba'«'nq2,u)  ,Z]  ,ziop,Bia) ; 
xi2>xiop; 


•/. 

%  defining/eolving  the  controller  problea-flt  cond  3 

% 

diap( 'eearching  for  nee  controller-  fit  cond  3*) 

CRa,Sc2]Bhinfrea6([A3  B23]  ,CD,B13*B13*  ,gaB,Z) ; 
laainBBax(elg(affin(Ra,xi3)))  *■  0.1; 

[xiop,laa3,atat,err2]>centere3b(Ra,Rb,Rc,Syy,zi3,laBin,  theta,  proc,lal2) ; 
if  err2‘«0, 

err>3:  return; 

elseif  laai3>B0, 

dispC ’centers  could  not  find  a  nee  feasible  controller  (fc3)’) 
break 
end 

YU3>affin([xeros(M'*'nq2,BA)  ,Z]  ,xiop,Ba); 
xi3«xlop; 


y. 

y,  defining/solving  the  ain  airfrane  problesi 

y. 

disp( ’Optiaixing  plant  for  previous  controller’) 
[Tcl,Sel]Bhinfres4(Aa,Bia,B2a,YVl,CD,gaa); 

[Tc2 ,  Sc2]  Bhinf  res4(Aa2 ,  Bla2 ,  B2a2 ,  YV2 ,  CD  ,gaai) ; 

[Tc3 ,  Sc3]  Bhinf  res4  (Aa3 ,  Bla3 ,  B2a3 ,  YW3 ,  CD  ,gaBi) ; 
y,  use  ’adiag’  to  stack  joint  constraints 
Tc>adiag(Tcl  ,Tc2) ;  TcBadiag(Tc,Tc3) ; 

Sc«[Scl;Sc2;Sc3] ; 
jBj'flOOOeeps; 

Czetaop,J,stat,err2]«centers3b(Ta,Tb,Tc, Sc, zeta,J,  theta, prec,lel2) ; 
if  err2-B0 
errB3 ; 
return ; 
end 

zetaBzetaop ; 

A«-«ffin(Aa,zeta) ;  BlBaffin(Bla,zeta,nql) ;  .  B2Baffin(B2a,zeta,uq2) ; 

A2Baffin(Aa2,zeta) ;  B12Baffin(Bla2,zeta,nql} :  B22Baff  in(B2a2,zeta,nq2) ; 

A3«affin(Aa3,zeta);  B13«affin(Bla3,zeta,nql);  B23Baffin(B2a3,zeta,nq2) ; 


JlB[laBl,laa2,laB3,J] ; 
disp(Jl) 
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J2*[J2;  luil,lMi2.1ui3.J]: 
if  it«ration>2, 

a  (J>0. 999999* J2(it*rAtion-l, 4))  I  lt«ration»60, 
break 
and 
and 


and 

X  Oataraina  tba  controller 

Yl>YUl(l:m.:):  Vl>TVl(Ba*l:Ba*nq2. ; ) ;  K1«V1/Y1; 

Y2>YU2(l:Ba.:):  V2>YV2(M-*’l:aa*nq2. : ) ;  K2>W2/Y2: 

Y3*YV3(  1  :aa . : ) ;  V3-YV3(m*l  :Ba*nq2, : ) ;  K3>V3/Y3 ; 

loglog(-J2(:.l),J2(:,4).'**.-J2(:,2),J2(:.4),*+*,-J2(:.3),J2(;,4),'x*), 
grid. titla( 'Plant  Coat  va.  Controller  Margin') 
xlabal  ( '  Controller  Margin ' ) ,  y label  ( '  Plant  Coat  * ) 

arr»0; 

return; 

X  and  plantoptS.a 


3.  Joint  Hoo  Pole  Placement  Plant/Controller  Optimization 

The  function  plantopt6  solves  the  pUnt/controller  optimization  problem 
where  joint  Hoo  and  pole  placement  performance  constraints  are  imposed.  The 
structure  is  identical  to  the  optimization  functions  above,  and  the  algorithm  follows 
Section  D..  The  administrative  functions  binfresG  and  hinfre84  above  create  the 
basis  matrices  for  the  Hoo  constraint,  while  polarasl  and  pol«r«82  create  the  basis 
matrices  for  the  pole  placement  constraint.  The  administrative  function  adiag  is  then 
used  to  create  the  joint  bases. 

The  significant  difference  between  this  code  and  the  previous  codes  is  that 
the  Riccati  solvers  prior  to  the  beginning  of  the  iterative  routines  could  only  find 
a  controller  that  satisfies  the  constraint,  which  was  no  guarantee  of  the  exis¬ 
tence  of  a  joint  controller.  The  first  pass  through  the  algorithm  therefore  started 
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with  a  controller  that  was  Ti^  feasible,  but  which  most  likely  failed  to  satisfy  the 
pole  placement  constraint.  The  first  pass  therefore  determined  the  feasibility  of  the 
problem.  As  mentioned  in  Chapter  V,  the  failure  of  the  algorithms  to  find  a  jointly 
feasible  state-feedback  controller  did  not  by  necessity  mean  that  a  feasible  controller 
did  not  exist. 


plantoptfi 

function 

[z«ta,xi,K,Z,Ra,Tc. J3.«rr]B. . . 

plant  opts  (  An .  B 1  a ,  B2n .  C ,  0 ,  zota  ,«•  Ight ,  rad ,  alpha .  thota ,  pr«c ) 

•/. 

'/•  [K ,  val ,  arr]  Bh2hlnf  af  (  Aa ,  Bla ,  B2a ,  C ,  D ,  zata  ,«aight .  gan ,  thata ,  prac ) 

'/.  CK, val, arr] Bh2hinfaf(Aa, Bla, B2a,C,D, zata, Haight, gam) 

•/. 

y,  Daicription: 
y.  Givan: 

y,  xdot  >  A  X  «  B1  H  B2  u, 

y,  z  B  C  X  4'  Du, 

'/t  y  '  X. 

y. 

y,  This  function  dataminas  tha  nininua  statafaadback  plant  satisfying 

y.  I  IT.zhI  Linfty  <  1,  and  closad-loop  polas  in  tha  circular  disc  of  radius  r 

y,  cantarad  at  (-(rad  *  alpha)  ,0), 

y. 

y,  min  J«Haight'*zata 
y,  sub j  act  to  tha  following 

y. 

y.  R(Z)»AY+YA*+B2W  ♦W'B2'+B1B1 '+(CY  +DH)'  (CY  +DW)<  0, 

y. 

y,  and 

y. 

y,  I  AlY+YAl'+B2W(I+Al/r)*+(I+Al/r)W'B2’+  AlYAl'/r  B2*W  I 

y.  R(Z)«  I  I  <  0, 

y.  I  V»B2'  -Y/r  I 

y. 

y. 

y,  vhara  Al^A  alpha*oya(A) 

y. 

y.  Coda  altarnativaly  finds  controllar,  and  minimizing  plant 
y.  using  tha  mathod  of  cantors. 

y. 

y.  Inputs: 

y. 

y,  C,D  aro  constant  matricas  from  tha  stata-spaca  raalization  of  tha  syston. 
y,  Aa,  Bla  and  B2a  ara  a-matricos  which  hold  tha  affina  alamants 
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y.  z«ta  i>  th«  vector  that  dolinai  the  initial  plant  (A>affin(AA,zeta)) 

X  weight  ie  the  row  vector  of  veighte  in  the  objective  function 
X  rad  and  alpha  specify  the  circle 
X  theta  paraaeter  of  the  aethod  of  centers 

X  prec  precision  in  the  coapute  of  the  upper  bound  of  the  B2  nora. 

X 

X  Outputs: 

X 

X  K  the  gain 

X  val  the  optiaua  value  of  the  perforaance  index  coaputed  by  centers 
X  algorltha 

X  err  error  code,  its  value  is  err>l  if  the  problea  is  infeasible, 

X  otherwise  err*0. 

X  Called  functions: 

X  basis,  coaputes  a  basis  for  a  set  of  block  structured  aatrices 
X  hinfres,  coaputes  the  a-aatrix  of  a  Riccati  inequality  restriction 
X  adiag,  coaputes  the  a-aatrix  of  diag(A(x),B(x)) 

X  atrace,  coaputes  the  a-aatrix  of  trace(R,X) 

X  aidant,  gives  an  a-aatrix  with  the  indept.  tera  equals  unity  and 
X  the  rest  of  aatrices  zeros. 

X  getvec,  gives  the  realization  of  a  aatrix  in  a  aatrix  basis. 

X  affin,  coaputes  an  affin  aatrix  function. 

X 

X  Conaants: 

X 

X  The  assuaptions  for  this  function  are  standard  in  the  state-feedback 
X  Hint  case,  (A,B2)  stabilizable  and  01  has  full  coluan  rank. 

X  These  assuaptions  are  not  checked,  though  they  probably  should  be. 

X  If  the  inputs  theta  and  prec  are  not  provided,  they  are  initialized 
X  to  0.1  and  0.001  respectively.  If  the  circle  paraaeters  are  not  specified 
X  then  they  are  set  for  a  circle  of  radius  87.3,  centered  at  -97.3  on  the  real 
X  axis, 
if  nargia<«9, 

theta«0.1;  prec«.001; 

if  nargin<9, 

rad>87.3;  alpha«0.6; 

end 
end 

[aa,na]«size(Aa) ;  diazsna/aa; 

Cnbl,nbl]«size(Bla) :  nql«nbl/dinz ; 

[ab2  ,nb2]  ssize(B2a) ;  nq2«nb2/dinz ; 

[ac,nc]>size(C); 

X  Detemine  hinf  feasibility/controller 
gsa«l: 

A«aff  in(Aa,zata) ;  Bl>aff  in(Bla,zeta,nql} ;  B2>aff  in(B2a,zeta,nq2) ; 

a«A-B2*((D'*D)\D')*C; 

han«Ca,  ((Bl*Bl*/gaa*2)-B2*((D'*D)\B2'));  -C'*(eye(ac)-D*((D**D)\D’))sC,  -a']; 
[xl  ,x2,fail]Bric_scbr(haa) ;  Xinf*x2/xl ; 

if  (fail>0)  I  any(eig(Xinf )<0) , 


raturn 


ditp( 'Initial  SyitMi  appaara  infaatibla-1*); 

alia 

diap( 'Initial  liaf  problaa  faaaibla*) 
and 

Kp>-(D'*D)\(D'*C<fB2'aXinf):  X  eontrollar 

X  Dataraina  partienlar  loln  Irom  eontrollar 
alsA-t-B2*Kp;  blsCBl,10000*aqrt(apt)*aya(M)] ;  clBC'fDaKp: 
[xl ,  z2  ,lail]  «rlc_aehr(  Cal  *  ,cl '  ael ;  -bl*bl '  .-al] ) ; 
yp*x2/xl; 

if  (fail>0)  I  any(aig(Yp)<0). 

diap( 'Initial  Systaa  appaara  infaaaibla-2');  ratum 
and 

«p»KpaYpj 


X 

X  Initializing  tha  optiaization 
X 

CZ,YY,diaz]Bbaaia2(aa,nq2) ; 
RbBayaOaaaaae,  (diazaDaOaaaaae) ) ; 
CD*CC  D]; 

Ta«C0,  aaight]: 
jBvaigbtazata; 
zi>gotvae2(CYp;Up] ,2); 


Syy>Cl.aa]: 
Rc«Czaroa(aa,aa) ,YY] : 

Tb>aya(l ,langtb(Ta) ) : 
laaa-l: 

J2Bn:  itarationaO; 


ahila  laa<>la>6, 


itaratioa«itarationai 

X 

X  dafining/aolving  tha  eontrollar  problaa 
X 

diapCaaarehing  for  naa  eontrollar'} 

[Ral,Sal]>hinfraa6(Ci  B2]  ,C0,Bl*Bi' ,gaa,Z); 

[Ra2 ,  Sa2]  >polar  aa  1  (  A ,  B2 ,  rad ,  alpha ,  Z ) ; 

X  uaa  adiag  to  fora  joint  eonatraint 
Ra«adiag(Ral .Ra2) ;  SaeBCSal ;Sa2:Syy] ; 

laBinmaz(aig(affin(Ra,zi)))  *  0.1; 

[ziop,laa,atat,arr2]>eantara3d(Ra,Rb,Re,Sac,zi,laain,thata,prae,lal2); 
if  arr2"»0, 

arr>3:  ratum; 

alaaif  laa>B0, 

diapCeantara  eould  not  find  a  nan  faaaibla  eontrollar') 
braak 

alaaif  lan>-la-6, 

diap( 'faaaibla  aat  too  aaall  to  procaad') 
braak 
and 

YWBaffin(Czaroa(aa<fnq2.aa)  ,Z]  ,xiop,aa); 

YBYU(l:na,:):  U«YV(aa'«'l:aa'fnq2, :) ; 

ziBZiop; 

K»W/Y; 
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% 

%  dalining/solving  th«  aln  airlram*  problm 

y. 

ditpCOptlaizing  plant  for  pravlout  controllar') 

[Tc  1 .  Sc  1]  >hinf  ras4  ( An .  B  la ,  B2a ,  YU ,  CD .  gaa) : 

CTc2  ,  Sc2]  >polaraa2  (  Aa ,  B2a ,  rad ,  alpha ,  Y ,  U) ; 

Tc«adiag(Tcl,Tc2):  StacB[Scl:Sc2]: 

J«J+0.1: 

[cataop,J,stat,arr2]«cantars3d(Ta,Tb,Tc.Stac.zata,  J.thata,prac,lal2); 
if  arrl-*© 

•rr>3; 

ratum: 

and 

zataBzataop: 

ABalfin(Aa,zata) ;  Bl^aff  ln(Bla,zata,nql};  B2Baffin(B2a,zata,nq2) ; 

dlapCCLaabda,  !]■') 

diap(Clan.J]) 

diapC’Clotad  Loop  PolaaB') 

E-alg(A-»B2*K) ;  diap(E*) 
if  any(raal(E)>sO), 
arr>4; 
raturn 
and 

J2>[J2;  Ian,  J.zata*]; 
if  itaration>2, 

if  (JaaJ2(itaration‘‘l,2))  I  itaratioaB>100, 
braak 
and 
and 


and 

diapC 'Final  Cloaad  Loop  Polas>') 

E>aig(A4^B2*X); 

di8p(E) 

loglog(-J2( : ,1) , J2( : ,2) , '•• ) .grid, 

zlabaK 'Controllar  Bargin' ),Ylabal( 'Plant  Coat') 

arraO; 

ratum; 

y.  and  plantopt0.B 


poleresl 


f unct ion  [F ,  Sf ] opolaras i ( A , B , rad , alpha , Z) 
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V. 

X  CF,Sf]Bpol«r«il(A|B,rad,«lpha,Z) 

X 

X  Description:  Pols  Plnesasnt  eonstrsint. 

X 

X  This  function  dstsminss  the  n-astrix  of  the  convex  restriction 
X  - 

X  I  Aiymi'+WKl*Al/r)*+(I+Al/r)W*B*+ AlYAl'/r  B*W  I 

X  R(2)*  I  I  <  0. 

X  I  WB*  -Yr  I 

X 

X 

X  Inputs: 

X 

X  A.B.rnd.elphs  peraaeters  of  the  restriction 
X  Z  basis  for  YU  froa  basis2 

X 

X  Outputs: 

X 

X  F  a-aatrix  of  the  restriction 
X  Sf  block  structure  of  F 
X 

X  Coaaents: 

X 

X  Bote  that  in  order  to  obtain  the  value  of  the  restriction,  as  need  a 

X  vector  x>Cxl . xr],  then  F(x)aF0't'Fl*xl'<-. .  .Fr^xr.  the  block  structure 

X  of  F(x)  is  Sf. 

X 

X  this  basis  is  for  pole  placeaent 

Cnz.nz]Bsise(Z): 

[aa,na]Bsize(A); 

Cab,nb]Bsize(B); 

diaBnz/aa;  anB2*aa; 

FBzeros(aa,an*diB) ; 

Al«A-«’alpha«eje(Ba) ; 
for  iBl:dia, 

YBZ(l:aa,(i-l)eaa'»'l:  (i-l)*aataa) ; 
UBZ(aa-*’l:aa'fnb,(i-l)eaa'»’i:(i-l)saa'»’aa) ; 

F2«B*V: 

F1bA1*Y  *  (Al/rad  ♦  e7e(aa))*F2' : 

F( :  .i*aa+l:  (i+l)*aa)»CFl+Fl’+  (Al*Y*Al'/rad),F2;F2'  ,-Y*rad]  ; 
end 

Sf«[l,aa]; 

return; 

X  end  poleresl 
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poleres2 

lunct ion  [F , Sf ] «pol«r«f 2 (in , B2n , rnd , alpha , Y , U) 

% 

%  CF,Sf]>pol«r«a2(ia,B2a, rad, alpha, Y,V) 

% 

%  Doscriptlon; 

y. 

%  This  function  dotominos  tho  a-aatrix  of  ths  convax  rsstriction 

y.  - 

y  I  (A'*-B*K'*'alpha*«ya)*Y>Y*(A-»B*K<*’alpha««ys)  *  (A4'B*K‘«’alpha*oyo)  I 

y.  R(Z)*  -I  I  >  0, 

y,  I  (A'»B*K*alpha*oy«)  -inv(Y/r)  I 

y.  - 

y. 

y.  Inputs: 

y,  rad, alpha, Y,V  paraastsrs  of  tho  rsstriction 
%  Aa,  B2a  bases  for  tho  plant 

y. 

y.  Outputs: 

y.  F  a-natrix  of  tho  rostriction  (rotums  R>0) 

X  Sf  block  structure  of  F 

y. 

y.  Cosmonts: 

X 

X  lots  that  in  order  to  obtain  tho  value  of  tho  restriction,  so  need  a 
X  vector  x>Cxl, . . .  ,xr]  ,  then  F(x)«F0'»'Floxl'«-. .  .Fr«xr,  tho  block  stmetura 
X  of  F(x)  is  Sf. 

X 

X  this  basis  is  for  polo  placonont 

[aa,na]Bsiso(Aa);  boib2*m; 

[nb,nb]Bsiso(B2a) ; 

dla«na/aa;  nq2>nb/dia; 

F>zoros(aa,aa*dia);  Fzszoros(Ba,aa): 

K*W/Y; 

Ai>ia(: ,l:aa); 

BiBB2a( : ,l:nq2): 

Fl>Ai-«-Bi*X'foyo(aa) ; 

F( : ,  1  :aa)»-CFl*Y+Y*Fl '  ,F1  ;P1  •  ,-inv(Y/rad)] ; 
for  i«2:dia, 

AWa( : ,  U-l)*aa'«'l : i*aa) ; 

BioB2a( : ,  (i-l)*nq2'fl :  i*aq2) ; 

Fl-Ai-fBivX; 

F( : ,  (i-l )oaa'«’l :  ioan)"- CF1*Y+Y*F1 '  ,F1  ;F1 '  ,Fx] ; 
and 

Sf>Cl,Ba]: 

return; 

X  end  poloros2 
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4.  Plant/Controller  Optimization  with  a  Joint  Hoc  Static  Maneu¬ 
verability  Specification 

The  design  code  plantopt2a  is  a  minor  modification  to  the  baseline  Hoo 
plant  optimization  code  plantopt2.  The  static  maneuverability  specification  must 
be  posed  as  the  basis  (in  C)  to  an  LMI  external  to  the  routine.  This  basis  Da  is  then 
passed  to  plantopt2a  as  an  input  variable.  During  the  plant  optimization  phase  of 
the  routine,  Da  is  diagonally  augmented  to  the  basis  for  the  Hoo  specification  using 
adiag.  Because  the  typical  termination  conditions  are  different  than  the  standard 
plant  optimization  problem,  the  termination  criteria  was  modified  slightly.  The  code 
that  follows  is  otherwise  identical  to  plantopt2,  and  required  no  additional  subrou¬ 
tines. 


plantopt2a 

function  Cz«ta,xi,X,Z,Rc,Tc,  J2,«rr]B. . . 

plantopt  2a(  Aa ,  B 1  a .  B2a ,  C ,  D ,  Dm  ,zota ,  «•  ight ,  thros ,  gui ,  thot  a ,  proc ) 

y. 

%Czata,zi,K,Z,Rc,Tc,  J2,«rr]«. . . 

%  plantopt2a(Aa,Bla,B2a,C,D,Da,zata,«aight,throa,gaa,thata,prac) 

% 

Vt  Daacription: 

%  Givan: 

y.  zdot  B  Az'fBl«'*'B2u, 

%z  ‘ex'*-  Du, 

y.  y  *  z, 

% 

%  This  function  dotarninai  tha  ainiaua  atata-faadback  plant  aatiafying 
y,  I  iT.zvl  Linfty  <  ganna  and  a  static  aanuvarability  apac  poaad  by  Da. 

y. 

%  ain  Jssaight'azata 
y.  subjact  to 

y. 

y.  R(xi,zata)=  AY+YA'+BZW  ♦W'B2'+  BIB1’*(CY  +DW)'(CY  +DW)  <  0, 

y. 

y,  and 
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% 

X  D(z«ta)  >  0 

y. 

%  Cod*  *lt*rnativ*ly  find*  central  controller,  and  ainlniclng  plant 
%  ueing  the  aethod  of  center*. 

X 

X  Input*: 

X 

X  C,D  are  con*tant  aatrice*  froa  the  *tate-spac*  realization  of  the  *y*t*a. 

X  Aa,  Bla  and  B2a  are  a-aatrice*  which  hold  the  affine  eleaent* 

X  zeta  i*  the  vector  that  define*  the  initial  plant  (ABaffin(AA,zata)) 

X  weight  i*  the  row  vector  of  weight*  in  the  objective  function 
X  thro*  i*  the  threehold  on  the  central  controller  nargin 
X  for  deteraining  when  to  quit  the  iterative  procedure 

X  gaa  i*  a  bound  of  the  1-inf  nora  for  the  cloead  loop  *y*tea. 

X  theta  paraaeter  of  the  aethod  of  center* 

X  prec  i*  u**d  by  the  aethod  of  center*  to  detemin*  when  to  quit  the  newton 
X  eearch  for  the  analytic  center.  The  default  i*  0.001,  bur  if  the  ricattl 

X  *oln  indicate*  that  the  problea  i*  feaaibl*  and  yet  the  aethod  of  center* 

X  cannot  find  a  aolution,  then  thi*  paraaeter  ahould  be  adjuated  to  aoaething 

X  aaaller  to  allow  the  newton  eearch  to  go  deeper. 

X  If  the  ricatti  eolver*  indicate  that  the  problea  i*  feaaibl*  and  yet  the 

X  aethod  of  center*  cannot  find  a  feaaibl*  controller,  then  thi*  paraaeter 

X  ahould  be  **t  aaaller. 

X 

X  Output*: 

X 

X  K  the  gain 

X  val  the  optiaua  value  of  the  perforaanc*  index  conputed  by  center* 

X  algoritha 

X  err  error  code,  it*  value  i*  *rr«l  if  the  problea  i*  infeaaible, 

X  otherwla*  *rr>0. 

X  Called  function*: 

X  baaia,  coapute*  a  baai*  for  a  aet  of  bloch  atructured  aatrice* 

X  hinfrea,  coapute*  the  a-aatrix  of  a  Riccati  inequality  reatriction 
X  adiag,  coapute*  the  a-aatrix  of  diag(A(x),B(x)) 

X  atrace,  coapute*  the  a-aatrix  of  trae*(R,Z) 

X  aidant,  give*  an  a-aatrix  with  the  indept.  tera  equal*  unity  and 
X  the  reat  of  aatrice*  zero*. 

X  getvec,  give*  the  realization  of  a  aatrix  in  a  aatrix  baai*. 

X  affin,  CMiputo*  an  affin  aatrix  function. 

X 

X  Craaent*: 

X 

X  The  aaauaption*  for  thi*  function  are  atandard  in  the  atate-feedback 
X  Hinf  caae,  (A,B1)  atabilizable  and  D1  ha*  full  colnan  rank. 

X  The**  aaauaption*  are  not  checked,  though  they  probably  ahould  be. 

X  If  the  input*  gaa,  prec  and  theta  are  not  provided,  they  are  initialized 
X  to  1,  0.1  and  0.001  reapectively. 
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11  nargin<ll 

gaacl;  th*ta«0.1; 

11  nurgln»7, 
thr«s«l«~6 

•nd 

•nd 

[■a,na]*slz«(Aa) ; 

[abl ,nbl]*ils«(Bla) ; 

Cab2 ,nb2] ■■lz«(B2a) ; 
[iBc,nc]Bslz«(C) ; 


pr«c« . 001 : 


dlBZ«na/M: 
nql«nbl/dlaz; 
nq2«nb2/dlBZ ; 


X  Dataraln*  hlnl  l«ztlblllty/c«ntral  controller 

Asallln(An,z«tn) ;  Blaallla(Bla,z«ta.nql} ;  B2>allla(B2a,zata,nq2) ; 
a«A-B2*((D**D)\D')eC; 

haa-Ca.  ((Bl*Bl>/gaB‘2)-B2*((D**D)\B2>)):  -C'*(aya(Bc)-D*((D*0)\D’ ))*C,  -a']; 
[xl ,  x2 ,  lall]  >rle_sehr  (haa) ;  Xlnl>x2/xl ; 

11  (lall>0)  I  any(olg(Xlnl)<0), 

dlsp( 'Initial  Systaa  appaara  lnlaasibla>l ' ) ;  return 

elee 

dlsp( 'Initial  Hlnl  problea  leatlble') 
end 

Kp«-(D'*D)\(D'*C+B2'*Xlnl);  X  "central"  controller 


X  Oeteralne  particular  tola  Iroa  central  controller 
al>A‘*'B2*Kp:  blaCBl,10000*eqrt(eps)«eye(aa)] ;  cl^CiD^Xp; 

[xl  ,x2,lail]«rlc_schr(C«l  *  iCl  '*cl  :-bl*bl '  »-al!)) ;  Yp*x2/xl ; 

11  (lall>0)  I  aBy(elg(yp)<0), 

dlip( 'Initial  Systea  appears  lnleasible*2');  return 
end 

Wp«Kp*Yp; 

X 

X  Initializing  the  optlalzatlon 
X 

[Z ,  YY  •  dlaz]  >basls2  (aa  ,nq2) ; 

RbBaye(aa-i-ae ,  (dlaz-t'l )  aCaa^ac ) ) ; 

CD*CC  D]; 

Ta»[0,  zelght]; 

Jsuelghtezeta; 
xl«getvec2(  [Yp;Hp] ,Z) : 


Syy«Cl,aa]; 
Rc>Czeros(aa,aa) ,YY] ; 

Tbseye(l.length(Ta)); 

laas'l; 

J2*n;  lteratlon«0: 


uhlle  laa<-le-12, 


It  erat  lon>lt  erat  lon'f  1 
X 

X  delinlng/solvlng  the  central  controller  problea 
X 

dlsp( 'searching  lor  now  central  controller') 
[Ra,Sc2]«hlnlroB6( [A  B2]  ,CD,B1*B1 '  ,gaa,Z) ; 
laain«aax(elg(allln(Ra,xl)))  ‘•■0.1; 
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Cxiop,lui,itat,«rr2]Be«Bt«ri3(Ra,llb.Rc,Syy.xl.luiln,th«ta,pr«c,l«12) ; 
if  •rr2*B0. 

•rra3;  return; 

•Ineif  laa»0, 

dlspCecnteri  could  not  find  n  now  fontiblo  controller *) 
break 

eleeif  lea>-thres, 

diepCfeneible  eet  too  ennll  to  proceed') 
break 

end 

YV«af  f  in(  [zeros  (■a'«nq2,u)  ,2]  ,ziop,a«) ; 

YbYU(1:m,:);  W«YV(BaM:M*nq2. :); 
zi*ziop: 

K»w/Y: 

X 

X  defining/solving  the  nin  airfraae  problem 
X 

dispCOptinlzing  plant  for  previous  controller') 

[Tc  1 .  Sc  1]  >hlnf  res4  ( As .  Bla .  B2a ,  YU ,  CD .  gam) ; 

Tc  ■  adiagCTcl.Oa): 

Sc  ■  [Scl;!  1]; 

[zat aop ,  J ,  stat ,  err2]  Bceat ers3 (Ta ,  Tb ,  Tc  .Sc ,  zeta .  J .  theta , prec .  1  e  12 ) ; 
if  err2*B0 
err»3; 
return; 
end 

zetaazetaop; 

ABaffin(Aa,zeta) ;  BlBaffin(Bla,zeta.nql);  B2Baffin(B2a.zeta.nq2); 
dispCClam.J]) 

J2bCJ2;  lam,  J,  zeta']; 
disp( 'Closed  Loop  Poles*') 

E«eig(AtB2*K) ;  disp(E') 
if  aay(real(E)»0). 
err»4; 
return 
end 

if  iteration>2, 

if  (J>O.909999eJ2(iteration-1.2))  t  iteration»100. 
break 

end 

end 


end 

X  Deteraiine  the  controller 

Y«YW(l:aA,:); 

U>YU(BM«l:aa+nq2.:); 

K»W/Y; 
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loglog(-J2( :  ,1) , J2(:  ,2), '*'),grid,tltl«('Plaiit  Cost  vs.  Controllsr  Margin') 
xlabsl  ( '  Cantral  Controllsr  Margin  ’ ) ,  ylabsl  ( *  Plant  Cost ' ) 

srr"0 ; 
return ; 

'/,  end  plantopt2a.B 

5.  Plant/Controller  Optimization  with  Dynamic  Maneuverability 
Constraints 

As  discussed  in  Chapter  V,  dynamic  maneuverability  requirements  can  ei¬ 
ther  be  imposed  using  a  closed-loop  ‘Hoc  constraint  or  second  formulation  based  upon 
determinantal  relationships.  For  the  first  method,  the  original  Hoc  code  plantopt2 
is  suitable  without  modification.  The  following  code,  plantopt9  use  the  Lyapunov 
formulation.  The  subroutines  actrcsl  and  actres2  perform  the  formation  of  the 
bases  matrices  of  the  LMI  associated  with  this  constraint. 

In  practice,  plantopt2  was  used  for  Example  problem  5,  and  the  following 
code  routinely  resulted  in  the  method  of  centers  departing  the  feasible  set.  This 
suggests  a  feature  in  the  geometry  of  the  constraint  which  centersS  could  not  handle. 
Given  more  rebable  interior  point  codes,  and  the  fact  that  both  formulations  were 
conservative,  it  would  be  interesting  to  see  which  of  the  two  formulations  for  the 
dynamic  maneuverability  requirements  resulted  in  a  lower  final  plan'  cost. 

plantoptQ 

lunction  Cz«ta,xi,K,Z,lla,Tc,J2,«rr]>. . . 

plantoptP  (  Aa ,  B  la ,  B2a ,  B3« ,  C ,  0 ,  z«ta ,  ««ight ,  uaax ,  thrai ,  that  a ,  pr«c ) 

X 

X  [zata,zi,K,Z,Ra,Tc,  J2,arr]>. . . 

X  plaiitopt9(Aa.Bla,B2a,B3a,C,D,z«ta,vaigbt,iiBaz,thata,prac) 

X  Czata,zi,K,Z,]ta,Te,J2,arr]«plantoptB(Aa,Bla,B2a,B3a,C,D,zata,vaight,inaz) 

X 

X  Deter ipt ion: 
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%  Glvan: 

%  xdot  «  A  z  B1  *  4'  B2  Q, 

X  z  B  C  z  Du, 

X  y  ■  X, 

X 

X  This  function  dstsrainss  ths  Biniuua  stuto-fssdbuck  plant  satisfying 
X  I  lT_z«|  Linfty  <  1,  and  opsn-loop  actuator  liuitation, 

X 

X  ain  J«*sight'*ssta 
X  sub j act  to  ths  following 

X 

X  R(Z)*  AYm'4-B2V  ♦W'B2'  +  B1B1»  +(CY+Dtf)(CY  +DW)  *  <  0 

X 

X  and 
X 

X  F(Z)«AY+B2V-fB3V(i,:)/njMz(i)  *  (AY-»^B2V-i-B3W(i. :  )/u_Baz(i)) '  <  0 
X 

X  Cods  altsrnativsly  finds  csntral  controllsr,  and  ainiaizing  plant 
X  using  ths  asthod  of  csntsrs. 

X 

X  Inputs: 

X 

X  C,D  ars  constant  aatricss  froa  ths  stats-spacs  rsalization  of  ths  systsa. 
X  Aa,  Bla,  B3a  and  B2a  ars  a-aatricss  which  hold  ths  affins  slsasnts 
X  Bla  corrsaponds  to  ths  szogsnous  disturbancs  inputs 

X  B3a  corrssponds  to  ths  szogsnous  coaaand  inputs 

X  zsta  is  ths  vsetor  that  dsfiass  ths  initial  plant  (ABaffin(AA,zsta)) 

X  wsight  it  ths  row  wsctor  of  wsighta  in  ths  objsctivs  function 
X  thrss  dstsrainss  ths  csntral  controllsr  margin  thrsshold  at  which 
X  ths  sst  of  fsasibls  control  is  considsrsd  too  snail  to  procssd 

X  Should  usually  bs  sst  to  ls-6  to  is-lO.  Dsfault>ls-9 

X  prsc  sstabliahss  how  dssp  ths  nswton  ssarch  will  procssd  looking  for 
X  ths  analytic  csntsr.  Dsfault«is-6 

X 

X  Outputs; 

X  z2  output  vsetor  zsta  of  ainiaizsd  plant  paraastsrs 
X  zi  vsetor  of  optinal  controllsr  paraastsrs 
X 

X  Callsd  functions: 

X  basis,  eoaputss  a  basis  for  a  sst  of  block  structured  aatricss 
X  hinfrss,  eoaputss  ths  a-aatriz  of  a  Riccati  inequality  restriction 
X  adiag,  eoaputss  ths  a-aatriz  of  diag(A(x),B(z)) 

X  atracs,  CMiputss  ths  a-aatriz  of  tracs(R,X) 

X  aidant,  givss  an  a-aatriz  with  ths  Indspt.  tern  equals  unity  and 
X  ths  rest  of  aatricss  zeros. 

X  gstvsc,  givss  ths  realization  of  a  aatriz  in  a  aatriz  basis. 

X  affin,  eoaputss  an  affin  aatriz  function. 

X 

X  Conmsnts: 

X 
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'/.  Th«  astuaption*  for  this  function  nrs  standard  in  ths  stats-fsadback 
y.  Hinf  caso,  (A,B2)  stabilizabls  and  D1  has  full  eolusm  rank. 

X  Thoss  assuaptions  aro  not  chscksd,  though  thsy  probably  should  bo. 

%  If  ths  inputs  thota  and  proc  aro  not  providod,  thoy  aro  initializod 
y.  to  0.1  and  0.001  rospoctivoly. 
if  nargin^BO, 

throsBlo-O;  thota>0.1:  proc>lo-6; 

olso  nargin<0 , 

orrorClnsufficont  nuabor  of  input  arguaonts*) 
and 

CBa,na]*sizo(Aa):  diaz>na/aa; 

[abl ,nbl]>sizo(Bla) ;  nql>nbl/diaz: 

[Bb2,nb2]«sizo(B2a) ;  nq2«nb2/diaz ; 

[Bc,ne]Bsizo(C) ; 

X  Dotomino  hinf  foasibility/contral  controllor 
gM*l; 

A>aff in(Aa,zota) ;  Bl^aff in(Bla,zota,nql) ;  B2Baff in(B2a,zota,nq2) ; 

B3>affin(B3a,zota,l) : 

a«A-B2o((D**D)\D‘)*C; 

haB>[a.  ((Bl*Bl'/gaa“2)-B2*((D**D)\B2’)):  -C**(oyo(Bc)-D*((D**D)\D’))*C,  -a*]; 
[xl ,z2,fail]Bric_schr(haa) :  Xinf«x2/xl ; 

if  (fail>0)  I  any(oig(Xinf)<0), 

diap( 'Initial  Systoa  appoars  inf oasiblo-l * ) ;  rotum 

olso 

disp( 'Initial  Hinf  probloB  foasiblo') 
and 

Kpa-(D'«0}\(0'oc<i>B2'«Zinf):  X  control  controllor 

X  DatorBino  particular  soln  froB  control  controllor 
al«A'fB2*Xp;  bl>CBl  ,10000osqrt(ops)ooyo(na)] ;  cl>C'fDoKp; 

[xl  ,z2,fail]«ric_schr([al '  ,cl  'ocl  ;-blobl '  ,-al]  ) ; 

Yp>x2/zl; 

if  (fail>0)  I  any(oig(Yp)<0), 

disp( 'Initial  Systoa  appoars  infoasiblo-2');  roturn 
and 

«p«Kp*Yp; 


X 

X  Initializing  tho  optiaization 
X 

[Z,YY,diBz]«basis2(aa,nq2) ;  Syy>Cl,aa] ; 

Rb3oyo(3*Ba-«-ac,(diBZ't-l)*(3*Ba'»^Bc));  Rc«[zoros(aa,aa) ,YY]  ; 

CD«CC  D]; 

Ta»[0,  soight];  Tb«oyo(l,longth(Ta)) ; 

J«soight*zota;  laa>-l; 

xi«gotvoc2(CYp;Up] .Z) ;  J2«C];  itaration>0; 

vhilo  laa<-lo-12. 

it  orat  ion«it  orat  ion<*'  1 
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% 

X  dcflning/solving  th«  e«itr»l  controllar  problm 
X 

dlfp( '■•arching  for  b««  contra!  controll«r*) 

[llal,Sal]BhiBfr«sd(U  B2] ,gan,2): 
CRa2,Sa2]«actr«sl(A,B3,B2,naax,Z) ; 

Ila>adiag(llal,lla2) ;  Sae*CSal;Sa2:Syy] ; 

lanin>nax(aig(affiB(lla.xi)))  ♦  0.1; 

[ziop,laa,*tat,«rr2]>c«Bt«ri3d(Ra.llb,Rc. Sac,  xi,laBin,th«ta,pr«c,  1*12) ; 
if  •rr2"«0, 

•rr«3;  return ; 

•Isoif  laa>B0, 

diipCcantars  could  not  find  a  now  foaaibl*  controller’) 
break 

•Ifeif  laa>-threa, 

diip('feaaible  net  too  aBall  to  proceed*) 
break 
end 

YH>aff  in(  Czeroi(M'»nq2,na)  ,Z]  .xiop.na) ; 

Y>YV(1:m.:);  V>YV(M4l:M4nq2. :); 
xi«xiop: 

K-H/Y; 

X 

X  defining/aolving  the  nin  airfrene  problen 
X 

dispCOptiaising  plant  for  previous  controller’) 
CTel,Scl]ehinfrei4aa.Bla.B2a,YV,CD,gaa): 

CTc2  ,  Sc2]  •actr  esZ  (  An .  B3a,  B2a ,  UMx ,  V ,  Y) : 

Tc«adiag(Tcl,Te2) :  Stac>CScl:Sc2] ; 

Cxetaop,  J ,  stat ,  errZ]  "centersldCTa.Tb.Tc.Stac  ,xeta,  J ,  theta, prec ,  iel2) ; 
if  errZ'-O 
•rr*3 ; 
return; 
end 

xeta>xetaop: 

A«aff  in(Aa,zeta) ;  Bl«aff  in(Bla,zeta,nql) ;  B2>aff  in(B2a,xeta,nq2) ; 

B3Baffin(B3a,zeta,l) ; 
dispC’CLaabda,  !]■’) 
disp([laB,J]) 

di«p( ’Closed  Loop  Poles*’) 

E«eig(A*B2*X) :  disp(E’) 

if  any(real(E)>*0) , 

•rr*4; 

return 

end 

J2>CJ2:  Ian,  J,zeta’]: 
if  iteration>2, 

if  (J»J2(iteration-l,2))  I  iterationB>100, 
break 
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•nd 


•nd 


«nd 

disp( 'Final  Closad  Loop  Polos>') 

E«tig(A4-B2*X); 

difp(E) 

loglog(-J2(:,l).J2(:,2),'*'),grid, 

xlabaK ’ Control  Controller  Margin *),ylabol(* Plant  Coat') 

arr«0 ; 
return; 

%  end  plantoptfi.B 


function  CF,Sf]Baetreal(i.B3,B2,uaax,Z) 

t 

%  CF,Sf]>actresl(A,Bl,B2.UBax,Z) 

% 

X  Deaeription:  Open-Loop  eonatraint. 

X 

X  Thia  function  deteminea  the  a-natrix  of  the  affine  reatriction 

X 

X  F(Z)«AY*B2V>B3U(i,:)/u_BUuc(i)  *  (AY^B2U4>B3U(i, : )/u.nax(i))'  <  0 
X 

X  Inputa: 

X 

X  A,B1,B2,ubax  paraaetera  of  the  reatriction 
X  Z  baaia  for  YV  fron  baaia2 

X 

X  Outputa; 

X 

X  F  a-natrix  of  the  reatriction 
X  Sf  block  atructure  of  F 
X 

X  Coanenta: 

X 

X  Bote  that  in  order  to  obtain  the  value  of  the  reatriction.  »e  need  a 

X  vector  xbCxI . xr],  then  F(x)«F0'»Fl*xi-<’. .  .Fr*xr,  the  block  atructure 

X  of  F(x)  ia  Sf. 

X 

X  thia  baaia  ia  for  open  loop  actuator  linitationa 
X 


nu«length(unax) ; 
DBZ,nz]Baize(Z): 
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[u,na]«siz«(A) ; 

[■b3,nb3]Btlz«(B3) ; 

[■b2,iib2]BBiz«(B2) ; 
diB«nz/M; 

F-Cl!  Sl-D; 
lor  kBl:ntt, 

FO>zoroi (■» • ■»* ( 1 ♦dia) ) ; 
for  i>l:diB, 

W«Z(Ba't'l  :BB'fiib2 .  (  i-1  )*BB‘f  1 :  ( i-l)*Ba‘»Ba) ; 
Fl>A*Y<^B2*W'fB3/uBu(k)*U(k. : ) ; 

FO(: ,lOBa+l:(l+l)OBa)BFl*Fl*; 

•nd 

F»«li»g(F.F0); 

Sf>[Sf:l.B«]: 

•nd 

ratum; 

V.  and  actraal 


actres2 


lunct Ion  CF , Sf ]  "aetratZC Aa .B3a , B2a ,UBax , V » Y) 

%  [F,Sl]>actrat2(Aa,B3a,B2a,uaz,W,Y) 

y. 

X  Daaerlption:  Opan-Loop  constraint. 

X 

X  This  function  dataminos  tha  a-natrix  of  tha  affina  rastriction 
X 

X  F(Z)«-(AY-»B2U*B3U(i.:)/a.Baz(i)  *  (AY*B2V^B3U(i, ; )/u.Baz(i)) ’ )  >  0 
X 

X  Inputs: 

X 

X  UBax,Y,W  paraBotars  of  tha  rastriction 
X  Aa,Bla,B2a  bases  for  tha  plant  paranatars 
X 

X  Outputs: 

X 

X  F  a-natriz  of  tha  rastriction 
X  Sf  block  structure  of  F 
X 

X  CoBBonts: 

X 

X  lota  that  in  order  to  obtain  tha  valua  of  tha  restriction,  *a  need  a 
X  vector  zb[z1,  . . .  ,xr] ,  than  F(z)BFO'*Fi*zi't’. .  .Frazr,  tha  block  structure 
X  of  F(z)  is  Sf. 

X 


236 


X  this  basis  is  for  opsn  loop  actuator  liaitations 

y. 


nu>lsngth(uaax) ; 

[■a,na]*sizs(Aa) ; 

Csib3,nb3]>siso(B3a) ; 

[siw,n«]Bsizs(V) ; 
dia«na/Ba; 

if  nb3>dia,  srror('B3  matrix  nasds  to  havs  ons  coluan’),and 
F*n;  Sf*a; 
for  kBl:nu, 

F0Bzoros(aa,aa*dia) : 
for  i>l:dia, 

Ai«Aa(: ,(i-l)saa*l:i*Ba): 

B3i>B3a(:.i): 

B2i«B2a(:  .(i-l}*aw4'l:i«Bs): 
Fl>Ai*Y4^B2i*V>B3i/ttaax(k)*V(k. : ) ; 

F0( : , {i-l)*aa+l :i*Ba)«-(Fl*Fl ’ ) ; 
and 

F»adiag(F.FO); 

Sf«[Sf:l.aa]: 

and 

ratum ; 
y.  and  actraa2 


6.  Plant/Controller  Optimization  with  Robustness  Constraints 
As  discussed  in  Chapter  V,  the  Koo  constraint  can  be  used  to  pose  ei¬ 
ther  disturbance  rejection  or  robustness  constraints  on  a  plant  optimization  problem. 
The  formulation  of  robustness  constraints  is  slightly  different  than  the  imposition 
of  turbulence  rejection  specifications  due  to  the  structure  of  the  problem.  A  sepa¬ 
rate  plant  optimization  function  (plantoptlO)  was  consequently  required,  as  well  as 
an  additional  subroutine  (hinfreaS)  which  could  form  the  basis  for  the  robustness 
constraint. 

plantoptlO 

function  Cz«ta,xi,K,Z,Ra,Tc, J2,«rr]*. . . 

plantopt  10  ( An ,  B  la ,  B2a ,  C ,  D  ,B3 ,  C3n ,  D3n ,  zuta ,  wuight ,  throz ,  thotn ,  proc ) 
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% 

%  [z«ta,xi,K,Z,Ra,Tc, J2,«rr]«. . . 

%  plantopt  10(Aa,Bla,B2«.C,D.B3,C3a,D3a,c«ta,««ight,thr«a,  theta,  pr«c) 

% 

y. 

V,  Description: 
y.  Given: 

%  xdot  •  A(seta)  x  ^  Bl(seta)  *  *  B2(zeta)  u  ‘f  B3  «3, 
y.  z  «  C  X  <f  Du. 

y.  z3  «  C3(zeta)x  *  D3(zeta)  u 

y  y  «  X. 

7. 

7,  This  function  detemlaes  the  aiininue  statefeedback  plant  satisfying 
y.  I  iT.zvl  l.infty  <  1,  and  I  |T_z3«3l  l.infty  <  1: 

y. 

y,  nin  J»*eight'*zeta 
y.  subject  to  the  following 

y. 

7,  R(Z)»  AY+YA*+B2H  +W*B2*+BiBl •♦(CY  +Dtf)*(CY  +D«)  <  0, 

y. 

7t  and 

y. 

y.  R(Z)*  AYm*4B2V  4V*B2'-»B3B3'-f(C3Y  4D3V)'(C3Y  -^D3U)  <  0, 

7, 

7%  Code  alternatively  finds  central  controller,  and  nininizing  plant 
%  using  the  nethod  of  centers. 

y.  This  function  was  specifically  intended  to  solve  the  hinf/hinf 
7*  problen  where  T.s3w3  is  the  uncertainty  transfer  function 
X  (and  the  plant  paraneters  show  up  in  (C3,D3)). 

y. 

X  Inputs: 

X 

y,  C,D,B3  are  constant  aatrices  fron  the  state-space  realization  of  the  systen. 

X  Aa,  Bla,  B2a,C3a,  and  D3a  are  a-natrices  which  hold  the  affine  elenents 
X  zeta  is  the  vector  that  defines  the  initial  plant  (AaaffinCAA.zeta)) 

X  weight  is  the  row  vector  of  weights  in  the  objective  function 
X  thres  detemines  the  controller  nargin  below  which  the  routine  quits 
X  theta  paraneter  of  the  nethod  of  centers 

X  prec  precision  in  the  compute  of  the  upper  bound  of  the  H2  nom. 

X 

X  Outputs: 

X 

X  K  the  gain 

X  err  error  code,  its  value  is  err«l  if  the  problen  is  infeasible, 

X  otherwise  err>0. 

7%  Called  functions: 

X  basis,  computes  a  basis  for  a  set  of  block  structured  natrices 
X  hinfres,  computes  the  a-matrix  of  a  Riccati  inequality  restriction 
X  adiag,  computes  the  a-matrix  of  diag(A(x),B(x)) 

X  atrace,  computes  the  a-natrix  of  traee(R,X) 
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X  aidant,  givas  an  a-utrix  with  tha  indapt.  tarn  aquala  unity  and 
y.  tha  raat  of  aatricaa  xaroa. 

y.  gatvac,  givaa  tha  raalixation  of  a  aatrix  in  a  Matrix  baaii. 
y.  affin,  conputaa  an  affin  matrix  function. 

y. 

y.  Conuants: 

y. 

y.  Tha  aaaunptiona  for  this  function  ara  standard  in  tha  stata-faadback 
y.  Hinf  casa,  (A,B2)  stabilisabla  and  D1  has  full  column  rank. 

X  Thasa  assumptions  ara  not  ckackad,  though  thay  probably  should  bo. 


[na,na]aaisa(Aa): 

[mbl ,nbl]asisa(Bla} ; 
Cnb2,nb2]asiza(B2a) ; 
Cnc,nc]asixa(C): 
[nc3,nc3]asisa(C3a): 

A«aff in(Aa,zata) ; 
C3aaff ia(C3a,zata,aa) ; 


dimzana/ma; 

nqlanbl/dimz; 

nq2anb2/dimx: 


Blaaffin(Bla,zata,nql): 

D3aaffin(03a,zata,nq2): 


B2Baff in(B2a,zata,nq2) ; 


X  Datamina  hinf  faasibility/contral  controllor 
gam*l; 

a>A-B2*((D*«D)\D>)*C; 

han«Ca.  ((Bl*Bl'/gam“2)-B2a((D'*D)\B2*)):  -C**(aya(mc)-D*((D'*D)\D'))*C,  -a»] 
Cxi,x2,fail]>ric.schr(haa) ;  Xinf«x2/xl: 

if  (fail>0)  I  any(aig(Xinf)<0). 

disp( 'Initial  Systam  appaars  infaasibla-i’);  ratum 

also 

disp( 'Initial  Hinf  problom  faasibla') 
and 

Xpa-(D'*D)\(D'*C'*’B2'*Xinf):  X  cantral  controllor 

X  Datamina  particular  soln  from  cantral  controllor 
alaA-t'B2'*Kp;  blaCBl,10000asqrt(aps)*aya(na)] ;  claCOaKp; 

[x 1 , x2 . fail] aric.schr ( Cal ' , c 1 ' act ; -blabl ' , -at] } ; 

Yp>x2/xl ; 

if  (fail>0)  I  any(aig(Yp)<aO) , 

dispC 'Initial  Systam  appaars  infoasibla-2');  ratum 
and 

VpaKpaYp; 

X 

X  Initializing  tha  optimization 
X 

[Z,YY,diaz]>basis2(na,nq2) ;  SyyaCl,ma] ; 

RbBaya(2*aa4'nctnc3,  (diaz4'l)a(2aaa‘«’nc'«'mc3) ) ; 

RcB[zaros(na,na) ,YY] ; 

CDb[C  D]; 

TaaCO,  maight];  Tbaayad.langthCTa)) ; 

Jasaightazata;  laa«-l; 
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xi>g«tv«c2([Yp;Wp] ,Z);  J2*[]:  it«ration«0: 

while  lui<-l«-12, 

i  t  erat  i  on«  it  er  at  lon'f  1 

y. 

%  dafining/solving  tha  controller  problen 

diapC’aearchiag  for  no*  controller') 

[Ral ,Sal]*hinfread(U  B2]  '  .gan.Z) ; 

[lla2,Sa2]>hinfrei6(CA  B2],CC3  D3].B3*B3'.gaa.Z); 

Sac« [Sal ; Sa2 ; Syy] : 

Ba«adiag(Bal  ,lla2) ; 
laain>Bax(eig(af f ia(Ba,zi) ) ) ; 
if  laain»0, 

lanin>laBin*l . 1 ; 
elae, 

lanin^laBin^'0 . 1 ; 
end 

Cxiop,lan,etat,err2]Beenters3d(lla,Rb,Rc.Sac,xi,laBin»theta,prec,le24) ; 
if  err2’«0, 

err>3:  return; 

elaeif  laai>B0, 

diapCcantera  could  not  find  a  new  feaaible  controller*) 
break 

elaeif  laa>>threa, 

diap( 'feaaible  aet  too  aaall  to  proceed*) 
break 
end 

YV>aff  in(  [zaroa(Ba'Hiq2,Bw)  ,Z]  .xiop.aia) ; 

T>YW(1  :na, : ) ;  VaYVCaa+l  laa't'nqZ, : ) ; 
xi«xiop: 

K»W/Y; 

X 

X  defining/aolwing  the  sin  airfraaie  problen 
X 

diapCOptinixing  plant  for  previoua  controller') 
[Tcl,Scl]ahinfrec4(Aa,Bla,B2a,YV,CD,gaB); 

CTc2 ,  Sc2]  >hinf  rea9  ( Aa ,  B2a ,  B3 ,  C3a .  D3a .  YV) 

TcBadiag(Tcl,Tc2);  StacBCScl:Sc2] ; 

3«J+1; 

[xetaop,  J,atat ,  err2]  >eentera3d(Ta,Tb,Tc,5tac,aeta,  J  ,theta,prec ,  le24) ; 
if  err2*B0 
errB3: 
return; 
end 

seta>setaop; 

A>aff in(Aa,xeta) ;  Bl>aff ln(Bla,zeta,nql);  B2Baffin(B2a,seta,nq2) ; 

CRaaff  in(C3a,seta,BHi) ;  OR^af  f  in(03a,zeta.nq2) ; 
diap( * [Laabda,  J]**) 
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dlsp(Clui,J]) 

diip( 'Closed  Loop  Polos*') 

E-oig(A*B2*X) ;  disp(E') 
if  sny(rosl(E)>*0), 
orr«4: 
return 

end 

J2bCJ2:  lea,  J, sets']; 
if  lterstion>2, 

if  (J»J2(iterstion-1.2))  I  iterstion*slOO, 
bresk 

end 

end 


end 

dispCFinsl  Closed  Loop  Poles*') 

E«eig(A4^B2*K) ; 
disp(E) 

if  isenpty(J2),  return,  end 
loglog(-J2(:,l).J2(:,2).'«'),grid. 

xlsbeK 'Centrsl  Controller  Margin '),y  label  ('Plant  Cost') 

err*0; 

return; 

%  end  plantoptlO.a 


itipftggg 

function  CR,Sf]*hinfres9(Aa,B2a,B3.C3a,03a,YV) 
y.  [R .  Sf ]  *hinf res4( Aa .  Bla .  B2a ,  YU ,  CD .  gaa) 

y. 

X  Description: 

X 

X  This  function  detemines  the  a-aatrix  of  the  convex  restriction 


X 

X 

- 

- 

X 

1  AY+B2U-«-YA'-^U'B2'4’B3B3' 

(C3Y+D3U) ' 

1 

X  R(zeta)  * 

1 

1  <  0, 

X 

1  (C3YfD3W) 

-  •y» 

1 

X 

- 

- 

X  This  subroutine  was  written  for  use  with  plantoptlO 

X  Bote  that  zeta_i  >  0  is  not  enforced  since  that  is  done  by  hinfres4 

X 

X  Inputs: 

X 
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'/•  Aa,B2A,C3a,D3ft  ar«  a-Mtric«i  of  th«  plant 

'/.  YW,B3  constant  paraaatars  of  tha  rostriction  (YW  is  ths  packsd  form  CY;V]) 

% 

%  Outputs: 

•/. 

*/.  R  a-aatrix  of  ths  rostriction  (-R>0  is  actually  rstumod) 

%  Sf  block  structurs  of  R 

X 

%  CoBUisnts: 

% 

%  lots  that  in  ordsr  to  obtain  ths  valus  of  tha  rostriction,  *s  nssd  a 

%  vsctor  x^Cxl . xr],  than  R(x)>RO-»'Risxl'». .  .Rr*xr,  ths  block  structurs 

%  of  R(x)  is  Sf. 

% 

[■a,na]Bsizs(Aa);  dinBna/na; 

[■b2 ,nb2] ■siso(B2a) ;  nq2Bnb2/din; 

[Bc3,nb3]Bsiza(C3a) ; 
ilBna+stcB; 

RBZsros(il,din*(il)) ; 

FlB[Aa(: .l:na),B2a(: ,l:nq2)]*YV; 

F2B[C3a(;  .l:Bia),D3a(:  ,l:aq2)] 

R(l:il,l:il)«-CFl+Fl**B3sB3*,  F2*:F2  ,-sys(nql)3; 

FSBssros(aic3) ; 
for  ial: din-1, 

Fl«  CAa( : ,  i*aa*l :  isaa-Hu)  ,B2a( : ,  isnq2-«-l :  i*nq24'nq2)]  sYV; 

F2>  CC3a( : ,  i*aa*l :  i^naHMi)  ,03a( : ,  isnq24-i :  isnq24-Bq2)]  *YV ; 
R(dia:il,(i«il+dia):(i*il4il})>-CFim',F2':F2,F3]; 
and 

SfCl,il]: 

rstum; 

%  and  hinfrasB 


7.  Joint  /  Pole-Placement  Plant/Controller  Optimization 

A  design  code  was  also  produced  to  solve  the  plant/controller  optimization 
problem  subject  to  a  joint  “H-x  /pole-placement  performance  constraint  (plantoptSb). 
The  yi-i  performance  measure  was  not  considered  to  be  as  useful  as  the  Hoo  problem, 
and  it  was  not  used  for  any  of  the  example  problems.  This  code  is  consequently 
included  for  archival  purposes  only.  The  subroutines  h2ra8l  and  h2ra82  prepared 
the  basis  matrices  for  the  constraint.  Interested  readers  should  consult  [Ref.  29] 
for  a  discussion  of  the  generalized  "Hx  cost.  The  derivation  of  the  expressions  used  in 


these  subroutines  is  straightforward  from  the  expressions  in  this  reference. 


plantoptSb 


function 

[zota,xi,K,Z,Ra,Rc,J2,orr]>. . . 

plantoptS  ( Aa .  B  la ,  B2a ,  C ,  0 ,  z«t  a ,  wolght ,  gaa,  thota ,  proc ) 

% 

%  [zata,zl,X.Z|Ra,Tc, J2,arr]*plantopt8(Aa,Bla,B2a,C,Dl,D2,zata,walght,gaa,thata,prac) 
%  Czata,zi,X,Z,Ra,TCi J2,arr]>plantopt8(Aa,Bla,B2a,C,Dl,D2,zata,waight) 

•/. 


'/.  Daacrlption: 

%  Givan: 

y.  xdot  B  A  z  B1  w  4'  B2  u. 
%z  •  C  X  *  40  u, 

%  y  •  X, 

% 


X  This  function  dataralnaa  tha  ainiBu*  plant  and  aaaoclatad  atata-faadback 
V.  controllar  aatiafylng  I  iT.zvl  L2(gan*l)  <  1.  and  clotad-loop  polaa  in  tha 
y,  circular  disc  of  radiua  r,  cantarad  at  (-(rad  *  alpha), 0).  Tha 
•/. 


y.  Bin  jB«aight'*zata 
%  tub j act  to  tha  following 
•/. 

%  I  AY4YA'4B2U  4V*B2'  B1 

%  R1(Z)«  I  Bl*  -aya 

%  10  0 

y,  I  0  0 

y. 


0 

0 

CYC '+DWC' ♦OW'D '-aya 
W'D' 


X  and 

y, 

%  I  AlY+YAl'+B2W(I+Al/r)'4(I+Al/r)W'B2'+ AlYAl'/r 

y.  R2(Z)*  I 

y.  I  V'B2’ 

y. 

y. 

y,  whara  Al*!  *  alphaaaya(A) 

y. 


0  I 

0  I  <  0, 
DW  I 
Y  I 


B2*W  I 

I  < 

-Yar  I 


y. 

y. 

y. 


Coda  altarnativaly  finds  controllar,  and  BiniBizlng  plant 
using  tha  Bathod  of  cantors. 


y.  Inputs: 

y. 


0, 


y,  C,01,D2  ara  constant  Batricas  froB  tha  stata-spaca  raalization  of  tha  systoB. 

y,  Aa,  Bla  and  B2a  ara  a-Batricas  which  hold  tha  affina  alawants 

y.  zata  is  tha  vactor  that  daflnas  tha  initial  plant  (ABaffin(AA,zata)) 

y,  waight  is  tha  row  vactor  of  waights  in  tha  objactivo  function 

y.  gSB  is  a  bound  of  tha  H-inf  nom  for  tha  closad  loop  systaa. 

y,  thota  paraBotar  of  tha  aathod  of  cantors 
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X  pr«c  prsciiion  in  th«  coaput*  of  th«  uppar  bound  of  tho  H2  nor*. 

X 

X  Outputs: 

X 

X  K  tho  gain 

X  vnl  tho  optimua  vnluo  of  tho  porfononco  indox  coaputod  bjr  cantors 
X  nlgoritha 

X  orr  orror  coda,  its  vnluo  is  orr*!  if  tho  probloa  it  infonsiblo, 

X  othorwiso  orr*0. 


X  Cnllod  functions: 

X  bntis2.  craiputos  n  basis  for  Y  and  V 
X  h2rot,  coaputos  tho  a-aatrix  of  tho  H-2  rostriction 
X  poloras,  coaputos  tho  a-aatriz  of  tho  polo  placoaont  rostriciton 
X  adiag,  coaputos  tho  a-aatrix  of  diag(A(x)  .B(x)) 

X  atraco.  coaputos  tho  a-aatrix  of  traco(R,X) 

X  aidant,  givos  an  a-aatrix  vith  tho  indopt.  tora  oquals  unity  and 
X  tho  root  of  aatricos  zoros. 

X  gotvoc2.  givos  tho  roalization  of  a  aatrix  in  a  aatrix  basis. 

X  affin,  coaputos  an  affin  aatrix  function. 

X 

X  Coaaonts: 

X 

X  Tho  assuaptions  for  this  function  aro  standard  in  tho  stato-foodback 
X  Hinf  caso,  (C1,A,B2)  dotoctablo  and  stabilizablo  and  D2  has  full  coluan  rank. 
X  Thoso  assuaptions  aro  not  chockod,  though  thoy  probably  should  bo. 


X  If  tho  inputs  gaa.thota  and  proc 
X  to  1,0.1  and  0.001  rospoctivoly. 
if  nargin*>8, 

gaa«l;  thota>0.1: 
and 

[aa,na]*sizo(Aa): 

[abl ,nbl] "sizoCBla) ; 
Cab2,nb2]asizo(B2a) ; 
[ac,nc]«sizo(C) ; 


aro  not  providod,  thoy  aro  initializod 


proca.OOl; 

dinz*na/aa; 
nql^nbl/diaz; 
nq2Bab2/diaz ; 


X  Inital  Plant 

A^aff  in(Aa,zota) ;  Bl«aff  in(Bla,zota,nql) ;  B2saff  in(B2a,zota,nq2) ; 

X  Find  a  good  starting  point  (in  tho  circlo,Yp>0,  and  (A'fBK)Y'fY(A4'BK) '-fBlBl'cO) 
PolosB [-6 : -1 : -4-aa] ; 

KpBplaco(A,B2, Polos);  X  warning:  placo  rotums  A-BX  stablo 

Yp>lyap( (A-B20Kp) ,B1*B1 ' ) ; 

Yp>(Yp-t-Yp')/2;  X  this  corrocts  for  inaccuracios  in  lyap 

WpB-Kp*Yp; 

CZ ,  YY ,  diaz]  Bbas  is2  (an  ,nq2 ) ; 
xiBgotvoc2(CYp;Up] ,2); 

X  Adain 
CD*CC  0]; 
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Ta«[0,  vaight]; 
J^vaightazata; 

J2b  □ ;  itaration«0 ; 


Tb«aya(l,langth(Ta)) ; 
laa>-l ; 


X  Sat  tha  circla  eritarion 

ra<l*87.3;  alpha^l; 

vhila  lam<- la-6, 

it  ar  at  ion«  it  arat  ion-*- 1 

y. 

y.  dafining/aolving  tha  eontrollar  problaa 

y. 

ditpCSaarching  for  aa*  eontrollar') 

CRl,Sl.R2,S2]*h2raal(3.CA  B2]  .C.D.B1*B1' .Z) ; 

[R3, S3]«polaraal(A,B2, rad, alpha, Z):  X  polaraa  iaplicitlj  aalorcaa  Y>0 
if  itaration»l, 

X  Nathazatically  tha  initial  zi  found  abova  ahould  satisfy  all  but  R2 
X  Kusiarlcally  it  doasn't  vork  that  wall  so  «a  first  naad  to  find  a  foasibla  xi 
RaBadiag(Rl ,R2) ;  Ra*adiag(Ra,R3) ; 

Rb"oya(aiza(Ra))i 
Rc«Czaros(Ba,aa) ,YY] ; 

Sac>[Sl;S2:S3:l,na]; 

also, 

Ra^Rl : 

X  lota  that  tha  eontrollar  nargin  juaps  sinea  tha  objaetiva  funetion  ehangas 
Rbsaya(aa,  (diaz-*'l)«aa) ; 

Re>adiag(-R2 , -R3) ; 

Sao>CSl;S2:S3]: 

and 

laain>aax(aig(affin(Ra,zi)))  4'  o.l; 

[xiop,laa,stat,arr2]«eantars3d(Ra,Rb,Re,Sae,xi,laaln,thata,prae,lal2)i 
if  arr2"«0, 

arr«3:  ratum; 

alsaif  laa>*0, 

dispCeantars  eould  not  find  a  naw  faasibla  eontrollar') 
braak 

alsaif  (itaration>l)  t  (lan>-la-6), 

disp( 'faasibla  sat  too  snail  to  proeaad') 
braak 
and 

YW>aff  in(  Czaros(aa4-nq2,aa)  ,Z]  ,xiop,na) ; 

Y>YW(1 :na, : ) ;  U>YV(na>l :na+nq2 , : ) ; 
xi>ziop: 

K«W/Y: 


X 

X  dafining/solving  tha  nin  airfrana  problaa 
X 

dispCOptinizing  plant  for  pravious  eontrollar') 
[Tol,Sel]>h2ras2(Aa.Bla.B2a,YV): 
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CTc2,Sc2]Bpol«rM2(Aa,B2a,r»d,ftlpha,Y,W); 

TcBadiag(Tcl,Tc2) ;  StaeB[Scl;Sc2] ; 

J»J+0.1; 

Czataop ,  J  .stat ,  •rr2]  ■e«ntar«3d(T&,Tb,Te  .Stac  ,  J  ,th«ta,pr«c ,  1«12) ; 

ii  arr2'»0 
arraS ; 
raturn; 
and 

zataBzataop: 

ABaffin(Aa,zata) ;  Bl^aff  in(Bla,zata,nql) ;  B2«aff  in(B2a,zata,nq2) ; 

dlspC  [Margin,  J]*’) 
dlap(ClaB,J]) 
diapC'Cloaad  Loop  Polaa*') 

BBaig(A^B2*K) :  diap(B*) 

if  any(raal(E)>BO), 
arraA; 
ratum 

and 

J2bCJ2:  Ian.  J] ; 
if  itaration>2, 

if  (jBBJ2(itaration-l,2))  I  itaration>BlOO, 
braak 

and 

and 


and 

diapC ’Final  Cloaad  Loop  Polas>’) 

E«aig(A«B2*X) ; 
diap(E) 

loglog(-J2( : ,  1) ,  J2( :  ,2) .  ’•’)  .grid, 
rlabalCControllar  Margin ’),ylabal(’ Plant  Coat’) 

aiTBO; 

ratnrn; 

*/,  and  plantoptS.n 


h2resl 


function  [F.Sf ,R,Sr]"h2raal(f ,AB,C,0,BlBi,Z} 

%  CF,Sf.R.Sr]>h2raal(f,AB.C,D,BlBl,Z) 

y. 

y,  Daacription: 

y. 

X  This  function  dataminaa  tba  a-aatricaa  of  tha  affina  raatrictiona 
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y.  asiociatfld  vith  th«  generalized  H_2  constraint. 

%  The  input  *1'  speeiliee  whether  the  H_2  constraint  is  to  use  the 
y.  naz  eigenvalue  (fB2)  or  the  naxinun  diagonal  elenont  (1*3). 

y. 

y.  1)  F*AB*yW  ♦  (AB*YW)'  +  BlBl  <  0, 

y.  and 

y.  2a)  1*2:  R*  I  CYC  -t-DVC-t-CW'D'-eye  DU  I 

y.  I  WD*  -Y  I  <0 

y.  or 

y.  2b)  1*3:  R*  I  dlag(dlag(CYC'  -fOUC'-fCU'D'-eye))  DU  | 

y.  I  U'D'  -Y  I  <0 

y. 

y.  lote  that  Y>0  is  inpllcitly  enlorced  within  R<0. 

y. 

y.  Inputs: 

y. 

y«  AB,C,D,B1B1  paraaeters  ol  the  restriction 
%  Z  basis  lor  YU  Iron  basis2 

y. 

y.  Outputs: 

y. 

y.  F  a-siatrlz  ol  the  restriction 
y.  SI  block  structure  ol  F 

y. 

y.  Comients: 

y. 

y.  Bote  that  in  order  to  obtain  the  value  ol  the  restriction,  we  need  a 
y.  vector  x*Cxl, . . .  ,zr]  ,  then  F(x)*F0>Fl*xl-*'. .  .Fr*xr,  the  block  structure 
y.  ol  F(x)  is  SI. 

[■z,nz]*size(Z) ; 

Csic,nc]*size(C) ; 

diB*nz/nc ;  Bui*nc-»’Sic ; 

F*zeros (nc , nc*dia) ; 

R*zeroB(nB,MiediB) ; 

F(: .l:nc)*BlBl: 

R(l:sic,l:ac)*-eye(ac) ; 

lor  i*l:dia, 

Y*Z(1  :nc ,  (i-l)*nc+l:  (i-l)*nc+nc) ;  U*Z(nc+l  :bz,  (i-l)*nc'fl :  (i-l)enc-»'nc) ; 
F1*AB*CY;U]: 

DU*D*U; 

F( : , i*nc+l : (i+1 ) •ne)*Fi+Fl * ; 
il  1**3, 

R( :  ,i*aa>l:  (i-M)*nB)*[diag(diag(C«Y*C'  ••■DU*C'«C*DU* ))  ,DU:DU'  ,-Y] ; 
elseil  1**2, 

R( : , i*Ba+l : ( i-H  )*Ba)*  C(C*Y*C  ’  ♦DU*C ’ +C*DU • ) , DU ; DU • , -Y] ; 

else, 

error(*l  aust  equal  either  2  or  3  in  h2resl*) 
end 
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and 

Sf«[l,nc] ; 
Sr^Cl.nc-t'ae] ; 
raturn ; 

%  and  h2raal 


h2re82 


function  CR,Sf]«h2ras2(in,Bla.B2a,YH) 

'/. 

%  CR,Sf]«li2ra82(Aa,Bln.B2a.YV) 

X 

X  Daacription: 

X 

X  Thia  function  dataninaa  tha  a-aatrix  of  tha  convax  raatriction 

X 

X  I  AY-»B2Vm‘4V'B2‘  B1  I 

X  R(zata)  >1  I  <  0. 

X  I  Bl«  -  aya  I 

X  - 

X  and  zata>0 
X 

X  lota  that  tha  aaeond  part  of  tha  H_2  conatraint  (aya~(C4’DX)Y(C^DK)*>0) 
X  ia  iadapaadant  of  sata! 

X  lota  alao  that  R<aata)  ia  indapandant  of  tha  aathod  by  which  tha 
X  R-2  conatraint  ia  iapoaad. 

X 

X  Inputa: 

X 

X  Aa,Bla,B2a  ara  a-aatricaa  of  tha  plant 

X  YV.gan  paraaatara  of  tha  raatriction  (YV  ia  tha  packad  fora  [Y;V]) 

X 

X  Outputa: 

X 

X  R  a-aatrix  of  tha  raatriction  (-R>0  ia  actually  ratnmad) 

X  Sf  block  atmctura  of  R 
X 

X  Coaaanta: 

X 


X  lota  that  in  ordar  to  obtain  tha  valua  of  tha  raatriction,  wa  naad  a 

X  vactor  x«Czl . xr],  than  R(x)*R0+Rl*xl-»'. .  .Rraxr,  tha  block  atructura 

X  of  R(x)  ia  Sf. 


X 

[na,aa]Baiza(Aa) ; 
[Bbl,nbl]Baica(Bla) : 
[Bb2,nb2]>aico(B2a) ; 
diaaBdia-l; 


diaBua/aa; 

nqlBnbl/dia; 
aq2Bab2/dia: 
ilBdias't’na'fnql ; 
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Fl>[Aa( : . 1 :■») .B2a( : , l:nq2)]*YU; 

Rszaros ( i 1 , dia* ( il ) ) ;  F3>z*ros (nql ) : 

R(dia:il,diH:il)>-[Fl'«’Fl' ,  Bla(:  .1  :nql) ;  Bla(:  ,1  :nql)  * ,  -cyaCnql)]; 
for  isltdiu, 

R(i,i+il*i)»l; 

FlB[Aa( : ,  i*aa4-l :  ioui-Ba)  ,B24( : ,  i*nq2-t'l  :i*nq2-«'nq2)]  *YV; 

F2>Bla(:  ,i*nql-i-l:i*nql4>nql) ; 

R(dim:  il ,  (i*il+di«) :  (i*il+il) )»- [Fl+Fl  •  ,F2:F2 *  .F3]  ; 

•nd 

Sf  s  [zaroi  (diaz ,  1 ) .  onozCdiaz ,  1 ) ;  1  .aa-t'nql] ; 
return; 

y,  end  h2reB2 


B.  EXAMPLE  SCRIPTS 

This  section  documents  the  scripts  which  were  used  in  the  preparation  of  the 
example  problems  of  Chapter  V.  The  principal  objective  of  these  scripts  is  to  take 
the  linear  aerodynamic  coefficients  and  translate  them  into  an  opendoop  state  space 
representation  that  reflects  the  dependence  on  the  optimization  variables  of  interests. 
The  outputs  Aa,Bla,B2a,C  and  D  are  then  the  primary  inputs  to  the  optimization 
functions  in  the  section  above.  The  section  below  follow  the  order  in  which  the 
examples  were  introduced  in  Chapter  V. 

1.  Example  !•  Optimal  Vertical  Tail  at  a  Single  Flight  Condition 
This  script  executes  the  directional  dynamics  example  illustrated  in  Chap¬ 
ter  V.  The  stability  derivative  data  for  a  F-4  aircraft  in  the  power  approach  flight 
condition  was  extracted  from  (Ref.  37].  The  functional  dependence  of  the  tail  size  was 
determined  using  the  relationships  in  [Ref.  40]  to  break  the  stability  derivative  data 
into  its  tail  and  wing/body  contributions.  The  formulae  for  the  plant  can  be  found  in 
equations  5.16.  This  script  also  provides  the  plant  bases  for  Example  problems  3  and 
4. 
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V,  Flight  condition  1 
V.  Appronch 

'/.  Script  ostablishos  n  diroetionnl  nircrnft  plant  for 
X  optinization  of  all-aoving  vortical  tail. 

X  f-4  data 

rho>0. 00238;  X  ■lnga/ft''3 
V*230:  X  fps 

Izz«133700;  X  alug-ft‘2 
S«B30;  X  ft*2 

b=38.7;  X  ft 

Sb-243.86;  X  ft‘2 

lb>63.12:  X  ft 

lt>19.8:  X  ft 

Tnaz  >  20000; 
lo  «  2.0; 

UMZ  «  30/67.3; 

Cnbwba-O. 00107;  X  yaw  Boaont  duo  to  bota  (ving/body) 

Cybt«0.426;  X  oido  forco  duo  to  bota  (tail) 

q«0.8*rho*V*V;  X  lbf/ft*2 

sigBabota>0.043;  X  varianco  on  diaturbanco 

X  build  functional  stato-opaco  roproaontation 
A0«C0  i;-Izz\q*S*b*Cab«b  -Zzz\2*q*S*b*{lt/V)*Cnb«b] ; 
A1«C0  0;*'lzz\q*'S«b*Cybt  -Izz\2*q*S*ba(lt/V)*Cybt] ; 

Aa>CA0  Al]; 

B10>C0  -Izz\q*S*boCnb«b] ’ ; 

B11*C0  -Izz\q*S*baCybt] ’ ; 

Blas[B10  Bllloaigaabota; 

B20«C0  0]’; 

B21bC0  >Izz\qaS*b*Cybt] ' ; 

B2a>CB20  B21] ; 

X  initial  paraaotora 

Vto>0.47;  X  original  tail  voliuao 

Vro>0.3oVto;  X  original  rolativo  ruddor  voluao 

zota* [Vto  ] * ; 
voight>Cl  ]; 

X  original  dynaaica 
Ao«aff ln(Aa,zota) ; 

B2o«affin(B2a,zota.l) ; 

X  aigaabota  ia  varianco  on  bota  diaturbancoa 


«ing  aroa 
oing  apan 

body  aurfaco  aroa 

body  longth 

tail  poaition  froa  eg 
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Bl*  [0 ;  -Izz\q*S*b*(Cab«b'*’Cybt*Vto)]  *«igBab«ta: 

C«Cl/0.035  0;  00]; 

D* Co ; 1/0. 1763: 

DRdyn>«ig(Ao) ; 
nat.lrqBzbi (DRdynC 1 ) ) ; 
daaplng«-coi(angl«(Dltdyn(l))) ; 

X  Conitruct  th«  baiiz  for  tho  static  aoBont  problsa  (sxaapls  4) 
Do  B  -Taax*ls; 

D1  B  q*Ssb*Cybt*iiBaz: 

Da  B  [Do.Dl] ; 

%  and  F4_opt_lb 


2.  Example  2-  Optimal  Vertical  Tail  at  Multiple  Flight  Conditions 
The  following  two  scripts  prepared  the  vertical  tail  optimization  problem 
at  high  subsonic  and  supersonic  flight  conditions.  These  were  then  used  in  concert 
with  the  script  in  the  above  slow  speed  script  to  perform  the  multiple  flight  condi¬ 
tion  example  problem.  The  synthesis  model  is  different  from  the  script  above  in  two 
respects.  First  of  all,  the  stability  derivatives  reflect  the  values  appropriate  to  the 
various  flight  conditions.  Secondly,  the  turbulence  rejection  specification  is  signifi¬ 
cantly  different,  and  required  different  scaling  of  the  input  and  output  vectors  w  and 
z.  Scaling  of  w  was  reflected  in  the  C  and  D  matrices,  while  scaling  of  w  was  reflected 
in  the  Bi  and  D  matrices. 
f4  opt  2b.m 


X  Flight  condition  2 
X  Subfonic  eruizo 

X  Script  ostabliihos  a  diroctional  aircraft  plant  for  vortical  optiaization. 
X  f-4  data 

rhoBO. 000739;  X  sluga/ft*3 

Vb876:  X  fps 

IZZB130800;  X  slug-ft‘2 

Sb630;  X  ft‘2  ving  area 
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b«38.7; 

Sb«243.86: 

lb>63.12; 

lt«19.8: 


%  It  «ing  span 

X  ft*2  body  turfaco  uroa 

X  ft  body  langth 

X  ft  tall  poaltion  froa  eg 


Cnb«b"-0. 00125 ;  X  ya«  aoaant  duo  to  beta  (aiag/body) 

Cybt«0.266;  X  aida  forea  duo  to  beta  (tail) 


q*0.S*rho*V*V;  X  lbf/ft*2 
■igaabatasO.OOST;  X  varianca  on  diaturbanca 


X  build  functional  atata-apaea  rapraaantation 
A0>[0  l:-*Iza\qaSab*Cnb»b  -Zss\2aq*S«b*(lt/V)*Cnb«b] ; 
A1»C0  0:-Zaz\q*SabaCybt  -lx*\2aq*S*b*<lt/V)*Cybt] ; 
Aa2>[A0  Al]; 


B10*[0  -Ixz\q*Sab«Cnb«b] * ; 
B11>C0  -Izz\q*Sab*Cybt] * : 
Bla2«CB10  Bll]*aigBabata: 

B20>C0  0]*; 

B21«C0  -IzzNqaSabaCybt] * ; 
B2a2-CB20  B21] ; 


X  initial  paraaatara 

Vto«0.47;  X  original  tail  voluaa 

Vro>0.3*Vto:  X  original  ralativa  ruddar  voluaa 

zata* [Vto  ] ' ; 
vaighfCl  ]; 

X  aigaabata  ia  varianca  on  bata  diaturbancaa 
Bl«  [0 :  -Zzz\q*Svba(Cabwb*CybtaVto)]  aaigmbata; 

C> Cl/0. 036  0;  0  0];  X  vaighta  raa  bata  to  ba  laaa  than  2  dag 

D«[0il/0.176];  X  uaighta  raa  ruddar  daflaction  to  ba  laaa  than  10  dag 


f4  opt  3b.ni 

X  Flight  condition  3 
X  Suparaonic  eruiaa 


X  Script  aatabliahaa  a  diraetional  aircraft  plant  for  vortical  tail  optiaization. 


X  f-4  data 

rho>0. 000287; 

V»1742; 

Zzz>139800; 

S>630: 

b»38.7; 

Sb>243.88; 

lb>53.12: 

ltBi9.8; 


X  aluga/ft‘3 
X  fpa 

X  alug-ft“2 

X  ft*2  wing  araa 

X  ft  wing  apan 

X  ft*2  body  aurfaca  araa 

X  ft  body  langth 

X  ft  tail  poaition  froa  eg 
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Cnb«b«-0. 00133; 
Cybt«0. 193; 


%  yM  uotunt  du*  to  bota  (»ing/body) 
X  tido  fore*  duo  to  bota  (tail) 


q*0.5*rho*V*V;  X  lbf/ft*2 
■igaabota«0.0029;  X  varianco  on  dlaturbanco 

X  build  functional  stata-apaco  roproaontation 
A0*[0  1 ; -Isz\q*S*b*Cnbab  -I**\2*q*S*b*(lt/V)*Cnbub] ; 

A1*[0  0;-I*z\q*S*b*Cybt  -I**\2*q*S*b*(lt/V)*Cybt] ; 

Aa3>[A0  A1  ]; 

B10s[0  ■*Izz\q*S*b*Cnbab]  * : 

B11*[0  -Izz\q*S*boCybt] ' ; 

Bla3«CB10  Bll]*BigBabata; 

B20*[0  0]*; 

B21«[0  -Izz\q*S*b*Cybt] * ; 

B2a3«[B20  B21]; 

X  Initial  paranatora 

Vto*0.47;  X  original  tail  voluna 

Vro«0.3aVto;  X  original  ralativa  ruddor  voluaa 

zata*  CVto] ' ; 

«aight«Cl  ]; 

X  algaiabata  ia  varianea  on  bata  diaturbancaa 
Bl>  Co ;  -Xzz\q«S*b*(Cnbab<»'Cybt*Vto)]  aaigzabata; 

C> Cl/0. 036  0;  0  0];  X  vaighta  na  bata  to  ba  laaa  than  2  dag 

D*C0;1/0.176];  X  vaighta  rva  ruddar  daflaction  to  ba  laaa  than  10  dag 


3.  Example  Three-  Optimal  Vertical  Tail  for  Joint  Tioo  Pole-Placement 
Specification 

The  Joint  Hoo  Pole- Placement  example  problem  used  the  identical  set  up 
script  as  example  one  above.  The  difference  was  that  a  different  optimization  function 
code  was  exercised  (plantopG  for  the  joint  constraint  in  lieu  of  plantopt2  for  the 
pure  Hoo  constraint). 
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4.  Example  Four*  Optimal  Vertical  Tail  for  Joint  Hoc  Static  Moment 

Specification 

Example  Pour  used  the  identical  set  up  script  as  example  one  above.  The 
difference  was  that  a  different  optimization  function  code  was  exercised  (plantop2a 
for  the  joint  constraint  in  lieu  of  plantopt2  for  the  pure  Hoo  constraint). 

5.  Example  Five/Six-  Plant  and  Controller  Optimization  with  Ma¬ 
neuvering  Constraints 

The  following  script  creates  the  bases  for  the  longitudinal  F-14  autoland 
problem.  The  aerodynamic  derivative  data  was  extracted  from  [Ref.  48],  and  the 
decomposition  into  the  wing/body  and  horizontal  tail  contributions  is  in  accordance 
with  [Ref.  40|.  The  coding  of  the  flight  dynamics  equations  was  verified  by  a  cross 
check  of  the  nominal  plant  ((,*  =  [1,  1]^)  with  a  linear  plant  extracted  from  a  lin¬ 
earization  of  the  nonlinear  equations  uschI  for  the  design  examples  of  Chapter  IV. 
This  routine  does  provide  the  bases  for  uncertainty  modeling,  though  this  was  not 
successfully  demonstrated  in  an  example  problem. 

This  model  does  not  include  actuator  dynamics.  Predecessors  did  include 
actuator  dynamics,  but  problems  were  encountered  in  solving  the  initial  feasibility 
problem  using  either  Riccati  or  interior  point  methods.  These  problems  were  at¬ 
tributed  to  the  stiff  geometry  that  the  actuator  poles  introduced.  See  the  script  for 
further  comments  regarding  its  use. 

The  plant  optimization  function  plantopt2  was  used  for  Example  Five, 
while  plantopt2a  was  used  for  Example  Six.  In  the  later  two  cases,  the  maneu¬ 
verability  constraint  was  passed  into  the  optimization  function  through  the  input 
variable  Da. 
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One  aspect  of  this  physical  example  is  contrived.  Specifically,  the  thrust 
was  fixed  for  the  problem  and  not  used  as  a  control  input.  This  was  necessary  in 
the  absence  of  actuator  models,  for  otherwise  the  optimization  routine  shifted  all  the 
control  energy  into  thrust  in  order  to  collapse  the  aerodynamic  surface  sizes. 

An  important  practical  issue  relevant  to  the  subject  of  the  general  prob¬ 
lem’s  geometry  was  observed  during  these  experiments.  The  method  of  centers  code 
centersS  has  a  numerical  input  argument  prec  which  determines  the  termination 
criteria  for  the  Newton  search  for  the  analytic  renter.  It  essentially  determines  how 
deep  the  search  must  go  before  it  is  considered  to  be  “close  enough”  to  the  optimal 
value.  In  a  strictly  affine  problem  prec  is  related  to  the  precision  of  the  final  output 
relative  to  the  optimal  value.  The  default  for  this  value  had  been  set  to  10“^,  which 
would  ensure  that  the  output  was  within  O.lof  the  optimal  value.  Because  of  our 
methodology  in  employing  the  method  of  centers  in  alternating  directions  across  the 
feasible  set,  this  was  no  longer  true.  The  output  for  the  above  problems  could  vary 
as  much  as  a  factor  of  20  if  prec  was  not  set  low  enough.  As  prec  was  adjusted 
from  10”®  to  10~®,  the  total  cost  at  the  conclusion  of  one  set  of  trials  improved  by 
a  factor  of  nearly  20.  No  further  improvement  was  then  noted  as  prec  was  adjusted 
from  10~®  to  10“®. 
fl4  opt  3.m 

*/«  Establish*!  plant  aatricas  for  flight  path  control  problsm  with 
*/,  stab  and  OLC  control  pos*r  adjustabl*. 

V.  Thrust  and  actuators  hav*  b*sn  r*aov«d. 

7,  This  probloe  is  hinf  foasibl*,  but  not  jointly  hinf  and  pol*-plac*B*nt 
%  foasibl*  for  (87.3,1)  circl*. 

7,  Conv*rg*s  succsssfully  vith  plantopt2  (hinf  only). 

7,  Th*  procision  arguntnt  for  plantopt2  must  b*  s«t  to  ls-6  or  snallar 
7,  to  find  th*  f*asibl*  controll*r. 


g-32.174; 

a>64000/g: 

Iyy>247194; 

Sb566  : 
cbu:>9.8; 
U«134*1.6889: 
N«.203; 

p«2116; 

Q».7*p*M*M; 

alph*>11.4/67.3: 

uObcos (alpha) *U : 

thOaalpha; 

slgM_CBdB3/67 . 3 ; 

sigM_alphaB6/U ; 

oBagalB40: 

oaaga2B80: 

OBaga3>6: 

rholBO. 1; 

rho2«0; 


X  fpa 
X  slugs 

X  slug-ft-2 
X  <t' 2 
X  *t 
X  fps 

X  lM/«t- 2 
X  lM/«t‘2 
X  rad 

X  rad  -  tria  point  is  Isvsl  flight 
X  rad 
X  rad 

X  rad/s  -  Actuator  bandsidths 
X  rad/s 
X  rad/s 

X  OLC  drag  to  lift  ratio 
X  DLC  aoasnt  to  lift  ratio 


X  F-14  stability  dsrivativs  data 
CLt>l. 49634913; 

CDt«0. 37406269; 

CMt«0; 

CDU>0; 

CLO»0; 

CNUbO; 

C0A>0. 0208*67. 3;  X  rad‘-l 

CLA«0. 0799*67. 3;  X  rad‘-l 

CMA— 0.0116*67.3;  X  rad*-l 

CLq-6.46;  X  rad‘-l 

CMQ— 14.3;  X  rad*-l 

CUDb-0.61;  X  rad‘-l 

CNAD«-0.93;  X  rad*-l 

CLZS>0. 0141*67. 3;  X  rad'-l 

CIIISb-0. 0201*67. 3;  X  rad*-l 

X  Seal*  initial  DLC  for  -0.1  g  accsl  at  full  dsfloction  of  0.6  rad 
CLOLC«-0.1*CLt/0.6;  X  rad*-l 

CDDLCBrhol*CLDLC;  X  rad*-l 

CNDLCBrho2*CL0LC; 

X  Dotsmins  ths  uing  body  dsrivativos: 

xcb-CNXS/CLIS  ;  X  ratio  of  tail  lovor  am  to  naan  chord 

CDAvb>CDA; 

CUvb>CU-CLZS; 

CNA«b>CNA-xe*CLXS; 

CLQ«b>CLQ-2*xc*CLXS ; 

CNqub«CNq*2*xe‘2*CLXS ; 

CLA0«bBCUD*2*xc*CLXS ; 
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CNA0«b*CNAD-2*xc‘2*CLIS: 


X  d«t«niln«  Rotation  Matrix  from  Lift/Orag  to  body  axia 
TsC-coa (alpha)  ain(alpha)  0:-ain(alpha)  -eoa(alpha)  0;0  0  ebar]; 

QTaQ^SoT; 

c2U>cbar/2/U; 

X  Dotonino  Corroetod  Inartia  Matrix 

J*diag([m*U,n*U,Iyy.l])-Cc2U*qT*C0  0  0;0  CLAD  0;0  CMAD  0  ],[0;0;0];0  0  0  0]; 

X  Build  aaro  blocki  of  atata  natricaa 
X  atataa  ara  u, alpha, q.thata, alpha/a, gaaHia_ar /a 
a00BC2*CDt  -CLt  0;2*CLt  COt  0;  2*CNt  0  0]; 

a01>[CDU/U  CDAab  0;  CLV/U  CUab  CLQwb*c2U:CMU/U  CMAvb  CMQ«b*c2U] ; 

a0>CQT*(aO0-»'a01),-Bag*Ccoa(th0);aln(th0):0];  0  0  10]; 

aO  ( 1 : 2 , 3 )  BaaUa  [-S  in  ( alpha ) :  coa  ( alpha )  ]  ■t’aO  ( 1 : 2 , 3 ) ; 

alB[qT*CLZSaCO  0  0:0  1  2*xc*e2U;  0  xc  -2*xc‘2*c2U] ,  C0;0;0]  ;0  0  0  0]; 

a2«zaroa(4,4) ; 

aOBj\aO;  al*J\al; 

X  control  inputa  ara  atab(rad) ,DLC  (rad),  thruat(lbf) 
bOBzaroa(4,2) ; 

bl>J\CqTa[0  0;CLIS  0:CM1S  0];0  0]; 
b2>J\CqT*C0  C0DLC:0  CLOLC  ;0  CMDLC  ];0  0  ]; 

X  Build  ayatam  natricaa 
A0«zaroa(8,6) ;  AlaAO;  A2>A0; 

A0(l:4,l:4)«a0;  Al(l:4,l:4)>al;  A2(l :4, 1 :4)Ba2; 

A0(5,2)«l; 

A0(e,C2,4])*[-l  1]; 

Aa«CA0  A1  A2]; 

X  axoganoua  inputa  alpha_diat,  gaana_cakl 
B10«  zaroa(6,2);  BIIbBIO;  B12«B10; 

B10(l:4,l)>a0(:  ,2)*aigBa_alpha;  B10(6,2)B-aigM_CMl: 

Bll(l:4,l)Bal(:  ,2)aaigna_alpha; 

B12(l:4,l)Ba2(:  ,2)aaigna_alpha; 

Bla«[B10  Bll  B12]; 

B20>  CbO;  0  0;0  0];  Bli-Cbi;  zaroa(2,2)];  B22«[b2;  zaroa(2,2)]: 

B2aBCB20  B21  B22] ;  X  factor  raquirad  to  achiara  hinf  faaaibility 

X  Build  Output  auktricaa 
X 

X  z*  [atab ,  DLC ,  al^a/a ,  gaBBa_arr/a ,  alpha] 

X 


C>s«ros(6,6):  01«z«ros(6,2):  D2B«y«(6,2): 

C(3:4,6:6)««y«(2): 

C(6,2)«l; 

%  Output  criteria: 

%  stab<20  deg 
X  DLC  <40  deg 
X  alpha_err<  1.6  deg 

zSeale-diag  (  [57 . 3/20 , 67 . 3/40 , .  0000 1 , .  00001 .67.3/1.6]); 
C>zScaleeC:  DlazScaleeDl ;  D2«zSealeeD2 ; 

zetaBCl0;10] ; 
wgt»C3,l] ; 

X  Build  ayatez  zatricea  for  uzeertaiaty  inputa  and  outputa 
DeltaB0.1*eya(6,3);  X  Scaling  for  lOX  uncertainty 

B3BDelta*QT: 

C3_0>QT\  J  (1:3.1: 3)  XQT*  [aOl .  zeroa  (3.3)]; 

C3_lBCqT\al(l:3.:)  .zeroa(3,2)] ; 

C3aB  CC3_0 .  C3_  1 ,  zeroa  (3 . 6)] ; 

D3a>qT\B2a(l:3,:): 

X  Add  open  loop  requirenent  to  naintain  a  zax  neg.  pitch  rate 
X  of  0.2  rad/aec  for  elev.  deflection  froz  triz  of  -20  deg 

de_zax  •  -20; 
q_zaz  <B  0.2; 

EO  •  A0(3.3)*q.zaz  *  B20(3.1)*de_zax/67.3; 

El  •  Al(3,3)eq_zax  ♦  B21(3,l)*de_zaz/67.3; 

E2  >  0; 

Ea  B  [BO  El  E2] ; 


X  end  fl4_opt_3 


6.  Example  Seven-  Plant  and  Controller  Optimization  with  Maneu¬ 
vering  Constraints  and  Directed  Thrust 

The  following  script  is  nearly  identical  to  the  script  above,  with  the  excep¬ 
tion  of  the  inclusion  of  directed  thrust.  The  directed  thrust  shows  up  principally  in 
the  B%  matrix  where  it  influences  both  the  closed-loop  controller,  and  the  open-loop 
maneuverability  constraint.  The  maneuverability  speciflestion  is  identical  to  that 
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applied  for  Example  Six. 
fl4  opt  4 

%  Establish**  plant  siatrlcss  lor  flight  path  control  problsn  with 
%  stab  and  OLC  control  power  adjustablo. 

%  Thrust  and  actuators  haws  boon  rsmovsd. 

y.  This  problsB  is  hint  fsasibls,  but  not  jointly  hint  and  pols-placsaent 
y.  fsasibls  for  (87.3,1)  circl*. 

y,  Converges  successfully  with  plantopt2  (hinf  only) . 

y.  The  precision  argunent  for  plantopt2  nust  be  set  to  le-6  or  snaller 

y.  to  find  the  feasible  controller. 


g«32.174; 
■■64000/g ; 
Iyy>247104; 

S*666  ; 
cbar39 . 8 ; 
U*134*1.6889; 
M>.203; 
p«2116; 

q>.7*p*N*N; 
alphaal 1.4/67. 3; 
uO«cos (alpha) *U: 
thO*alpha: 
s igna.cnd«3/67 . 3 ; 
sigaa_alpha«6/U ; 
on*galw40: 
on*ga2>80; 
osioga3*6 : 
rhol«0.1; 
rho2>0; 


X  fps 
X  slugs 
X  slug-ft*2 
X  ff2 
X  ft 
X  fps 

X  lbf/ft*2 
X  lbf/ft*2 
X  rad 

X  rad  -  trin  point  is  level  flight 
X  rad 
X  rad 

X  rad/s  -  Actuator  bandwidths 
X  rad/s 
X  rad/s 

X  DLC  drag  to  lift  ratio 
X  DLC  nosient  to  lift  ratio 


X  F-14  stability  derivative  data 
CLt*l. 49634913; 

CDt>0. 37406289; 

CNt>0; 

CDU>0; 

CLU>0; 

CMU*0; 


CDA>0. 0208*67. 3;  X  rad*-l 
CLA>0. 0799*67. 3;  X  rad‘-l 
CMA«-0.0116*67.3;  X  rad*-l 
CLq>6.46;  X  rad‘-l 
CMq«-14.3:  X  rad--l 
CLAD«-0.61;  X  rad‘-l 
CMAD«-0.93;  X  rad*-l 

CL]lS«0. 0141*67. 3;  X  rad“-l 


CNXS>-0. 0201*67. 3; 


X  rad*-l 


X  Seal*  initial  OLC  for  -0.1  g  aecal  at  full  daflaction  of  0.5  rad 
CLDLC>-0.1*CLt/0.6;  X  rad‘-l 

CDDLC>rhol*CLDLC:  X  rad*-l 

CN0LC>rho2*CLDLC; 

X  Dataraino  tha  wing  body  darivativaa: 

zc>-CNIS/CLlS:  X  ratio  of  tail  lavar  am  to  aaan  chord 

CDAwb*C0A; 

CUwb«CU-CLIS; 

CNA»b«CMA-xc*CLZ5: 

CLQ»b>CLQ-2*xe*CLZS ; 

CNqwb>CNq*2*xc‘2*CLZS ; 

CLADab>CLAD*2*ze*CLIS ; 

CNADwb>CMAD-2*xc‘2*CLIS ; 

X  datamina  Rotation  Matrix  from  Lift/Drag  to  body  axis 

T« [-cos (alpha)  sinCalpha)  0:-sln(alpha)  -cos(alpha)  0;0  0  ebar] ; 

qT*q*S*T; 

c2U>cbar/2/U: 

X  Datamina  Corraetad  Inartia  Matrix 

J«diag(Di*U,B*U.Zyy,l])-Ce2U*qT*C0  0  0:0  CLAD  0;0  CHAD  0  [0:0:0]  ;0  0  0  0]: 

X  Build  aaro  blocks  of  stats  aatricas 
X  statas  ara  u, alpha, q.thata, alpha/s •gaaaa.ar/s 
a00>C2*CDt  -CLt  0:2«CLt  CDt  0;  2*CMt  0  0]: 

a01«[C0U/U  CDAab  0:  CLU/U  CUsb  CLq«b«c2U:CNU/U  CNAvb  CMq«b*c2U] ; 
a0>[qT*(a00*a01),-a*g*[cos(th0);sin(th0):0]:  0  0  10]; 
aO(l:2,3)aa*U*  C-sin(alpha);cos(alpha)]*a0(l:2,3): 
al>[qT*CLZS*[0  0  0;0  1  2*xc«c2U;  0  xc  -2*xc“2*c2U] ,  [0;0;0]  ;0  0  0  0]; 
a2>zaros(4,4) ; 

aOaJVaO;  al«J\al; 

X  control  inputs  ara  stab(rad),DLC  (rad),  thrust (Ibf) 
b0>saros(4,2): 

bi>j\CqT*Co  0:azs  0:CMZS  o]:o  o]; 
b2«J\CqT*[0  CDDLC:0  CLDLC  :0  CMDLC  ]  :0  0  ] ; 

X  ersata  diractad  thrust  control  input 
TO  >  13118; 
thataaO  ■  0/57.3; 

Px  B  xc  *  3;  X  thrust  lavar  am 

Bdt  «  zaros(6,l); 

Bdt(l)  ■  -T0*sin(thataa0)/a; 

Bdt(2)  •  -T0*cos(thataa0)/(a*U) ; 

Bdt (3)  ■  -Px*T0*cos(thstaa0)/n; 


X  Build  systaa  aatricas 


A0*z«rot(6,6):  A1>A0;  A2-A0; 


A0(l:4.1:4)«a0;  Al(l:4.1:4)«al;  A2(l:4,l;4)*a2 

A0(B,2)»1; 

A0(6,[2,4])*C-1  1]; 

Aa«[AO  A1  A2] : 

'/.  axogcnoua  input!  alphn_dl!t.  gaaa!_cnd 
BIOS  zaro!(6,2) ;  BllsBlO;  B12sB10: 

B10(l;4,l)sa0(: ,2)*aigB!_alph!:  B10(6,2)s-aigBa_cwi; 

Bll(l:4,l)«al(: ,2)atigBa_alpha; 

B12(l:4,l)«a2( :  ,2)*ilgM_alpha; 

Blas[B10  Bll  B12]; 

B20s  [bO;  0  0:0  0]; 

B20(:.l)  s  B20(:,l)  *  Bdt; 

B21s[bl;  zaro!(2.2)]: 

B22«[b2;  zaro!(2,2)]: 

B2a«[B20  B21  B22] ;  V.  factor  raquirad  to  achiava  hinf  faaaibility 

*/,  Build  Output  aatricaa 
X 

%  zs  Catab .  DLC ,  alpha/t ,  gaaa!_«rr/s ,  alpha] 

y. 

Cszaroa(6.6) :  Dlszaros(6,2):  D2saya(5,2}; 

C(3:4,6:e)saya(2): 

C(5,2)«l; 

y.  Output  critaria: 
y.  itab<20  dag 
y.  DLC  <40  dag 
X  alpha. arr<  1.6  dag 

zScalasdiag( [67 . 3/20,67 . 3/40,  .00001 ,  .00001,67.3/1 . 6] ) ; 

CszSealaaC;  DlszSealaaOl;  D2szScala*D2 ; 

zatas[10;10] ; 

■gts[3,l]; 

X  Build  syataa  aatricas  for  uncartainty  inputs  and  outputs 
Daltas0.iaaya(6,3);  X  Scaling  for  lOX  uncartainty 

B3sDaltaaQT; 

C3.0«QT\J(l:3,l:3)\qTaCa01,zaroa(3,3)]: 

C3_ls[qT\al(l:3, :),zaros(3,2}] ; 

C3asCC3_0,C3_l,zaros(3,6)] ; 

D3asQT\B2a(l:3,;); 
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X  Add  optn  loop  roquiroaont  to  Btintaia  o  box  nog.  pitch  rat* 

%  of  0.6  rad/»oe  for  olov.  daflaction  froB  tria  of  -20  dag 
V.  and  a  thrust  daflaction  of  6  dagraas  at  20  Klbs 

da_Bax  «  -20; 
q_Bax  >  .6; 
thataa_Bax  ■  -20; 

EO  B  A0(3,3)aq_Bax  ♦  B20(3,l)*da_nax/67.3  *■  Bdt(3)*thataa_Bax/67.3; 

El  >  Al(3.3)aq_Bax  *  B21(3,l)*da.Bax/67.3: 

E2  «  0; 

Ea  «  [EO  El  E2] ; 

thata  ■  0.1;  gaa  ■  1;  prac  •  la-6;  thras  «  la-9; 

[z2,xl,X,Z,Rc,Tc,J2,arr]>plaBtopt2a(Aa,Bla,B2a.C,02,Ba,sata,«gt,thras,gaa,thata,prac); 
X  and  fl4_opt_4 
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